diff --git a/audio/audio_driver.c b/audio/audio_driver.c
index c2d00a6cfe..8c3ba0aac6 100644
--- a/audio/audio_driver.c
+++ b/audio/audio_driver.c
@@ -172,7 +172,7 @@ audio_driver_t *audio_drivers[] = {
NULL,
};
-static audio_driver_state_t audio_driver_st; /* double alignment */
+static audio_driver_state_t audio_driver_st = {0}; /* double alignment */
/**************************************/
@@ -1872,7 +1872,7 @@ bool audio_compute_buffer_statistics(audio_statistics_t *stats)
#ifdef HAVE_MENU
void audio_driver_menu_sample(void)
{
- static int16_t samples_buf[1024];
+ static int16_t samples_buf[1024] = {0};
settings_t *settings = config_get_ptr();
video_driver_state_t *video_st = video_state_get_ptr();
uint32_t runloop_flags = runloop_get_flags();
diff --git a/frontend/drivers/platform_win32.c b/frontend/drivers/platform_win32.c
index 3a9c1e6170..26ed25c04f 100644
--- a/frontend/drivers/platform_win32.c
+++ b/frontend/drivers/platform_win32.c
@@ -85,7 +85,7 @@ static uint8_t g_plat_win32_flags = PLAT_WIN32_FLAG_USE_POWERSHELL;
VOID (WINAPI *DragAcceptFiles_func)(HWND, BOOL);
/* TODO/FIXME - static global variables */
-static char win32_cpu_model_name[64];
+static char win32_cpu_model_name[64] = {0};
#ifdef HAVE_DYLIB
/* We only load this library once, so we let it be
* unloaded at application shutdown, since unloading
diff --git a/gfx/display_servers/dispserv_android.c b/gfx/display_servers/dispserv_android.c
index 3e183e9542..47f008604e 100644
--- a/gfx/display_servers/dispserv_android.c
+++ b/gfx/display_servers/dispserv_android.c
@@ -43,10 +43,10 @@ static void android_display_server_set_screen_orientation(void *data,
static void android_display_dpi_get_density(char *s, size_t len)
{
- static char string[PROP_VALUE_MAX];
- static char string2[PROP_VALUE_MAX];
static bool inited_once = false;
static bool inited2_once = false;
+ static char string[PROP_VALUE_MAX] = {0};
+ static char string2[PROP_VALUE_MAX] = {0};
if (!inited_once)
{
system_property_get("getprop", "ro.sf.lcd_density", string);
diff --git a/gfx/drivers/omap_gfx.c b/gfx/drivers/omap_gfx.c
index 607244d427..517f4b410e 100644
--- a/gfx/drivers/omap_gfx.c
+++ b/gfx/drivers/omap_gfx.c
@@ -85,7 +85,7 @@ typedef struct omapfb_data
static const char *omapfb_get_fb_device(void)
{
- static char fbname[12];
+ static char fbname[12] = {0};
settings_t *settings = config_get_ptr();
const int fbidx = settings->uints.video_monitor_index;
diff --git a/gfx/gfx_display.c b/gfx/gfx_display.c
index f6452818c7..d69cb2da1c 100644
--- a/gfx/gfx_display.c
+++ b/gfx/gfx_display.c
@@ -35,7 +35,7 @@
static uintptr_t gfx_white_texture;
/* ptr alignment */
-static gfx_display_t dispgfx_st;
+static gfx_display_t dispgfx_st = {0};
gfx_display_t *disp_get_ptr(void)
{
diff --git a/gfx/gfx_thumbnail.c b/gfx/gfx_thumbnail.c
index da91368f16..5996843b8c 100644
--- a/gfx/gfx_thumbnail.c
+++ b/gfx/gfx_thumbnail.c
@@ -46,7 +46,7 @@ typedef struct
gfx_thumbnail_t *thumbnail;
} gfx_thumbnail_tag_t;
-static gfx_thumbnail_state_t gfx_thumb_st; /* uint64_t alignment */
+static gfx_thumbnail_state_t gfx_thumb_st = {0}; /* uint64_t alignment */
gfx_thumbnail_state_t *gfx_thumb_get_ptr(void)
{
@@ -289,10 +289,10 @@ void gfx_thumbnail_request(
/* Handle on demand thumbnail downloads */
else if (network_on_demand_thumbnails)
{
- static char last_img_name[NAME_MAX_LENGTH];
enum playlist_thumbnail_name_flags curr_flag;
const char *system = NULL;
const char *img_name = NULL;
+ static char last_img_name[NAME_MAX_LENGTH] = {0};
settings_t *settings = config_get_ptr();
if (!playlist)
goto end;
diff --git a/gfx/gfx_widgets.c b/gfx/gfx_widgets.c
index f4e918fa68..d7e79d50fa 100644
--- a/gfx/gfx_widgets.c
+++ b/gfx/gfx_widgets.c
@@ -65,7 +65,7 @@ static const char
"menu_achievements.png"
};
-static dispgfx_widget_t dispwidget_st; /* uint64_t alignment */
+static dispgfx_widget_t dispwidget_st = {0}; /* uint64_t alignment */
static void INLINE gfx_widgets_font_free(gfx_widget_font_data_t *font_data)
{
diff --git a/gfx/video_crt_switch.c b/gfx/video_crt_switch.c
index 36260306d7..b73f28af47 100644
--- a/gfx/video_crt_switch.c
+++ b/gfx/video_crt_switch.c
@@ -515,12 +515,12 @@ static void crt_rpi_switch(videocrt_switch_t *p_switch,
{
int w;
char buffer[1024];
- static char output1[250];
- static char output2[250];
- static char set_hdmi[250];
- static char set_hdmi_timing[250];
VCHI_INSTANCE_T vchi_instance;
VCHI_CONNECTION_T *vchi_connection = NULL;
+ static char output1[250] = {0};
+ static char output2[250] = {0};
+ static char set_hdmi[250] = {0};
+ static char set_hdmi_timing[250] = {0};
int i = 0;
int hfp = 0;
int hsp = 0;
diff --git a/gfx/video_driver.c b/gfx/video_driver.c
index 383223dba5..7fd30956d8 100644
--- a/gfx/video_driver.c
+++ b/gfx/video_driver.c
@@ -3229,10 +3229,10 @@ const char* video_driver_get_gpu_api_version_string(void)
bool video_driver_init_internal(bool *video_is_threaded, bool verbosity_enabled)
{
video_info_t video;
- static uint16_t dummy_pixels[32];
unsigned max_dim, scale, width, height;
video_viewport_t *custom_vp = NULL;
input_driver_t *tmp = NULL;
+ static uint16_t dummy_pixels[32] = {0};
runloop_state_t *runloop_st = runloop_state_get_ptr();
settings_t *settings = config_get_ptr();
input_driver_state_t *input_st = input_state_get_ptr();
diff --git a/input/drivers/sdl_input.c b/input/drivers/sdl_input.c
index 996e9209a0..169e92bffa 100644
--- a/input/drivers/sdl_input.c
+++ b/input/drivers/sdl_input.c
@@ -63,7 +63,7 @@ enum sdl_webos_special_key
sdl_webos_spkey_size,
};
-static uint8_t sdl_webos_special_keymap[sdl_webos_spkey_size];
+static uint8_t sdl_webos_special_keymap[sdl_webos_spkey_size] = {0};
#endif
static void *sdl_input_init(const char *joypad_driver)
@@ -249,7 +249,7 @@ static int16_t sdl_input_state(
if (idx == 0)
{
struct video_viewport vp;
- bool screen = device ==
+ bool screen = device ==
RARCH_DEVICE_POINTER_SCREEN;
const int edge_detect = 32700;
bool inside = false;
@@ -275,7 +275,7 @@ static int16_t sdl_input_state(
res_y = res_screen_y;
}
- inside = (res_x >= -edge_detect)
+ inside = (res_x >= -edge_detect)
&& (res_y >= -edge_detect)
&& (res_x <= edge_detect)
&& (res_y <= edge_detect);
@@ -397,7 +397,7 @@ static void sdl_input_poll(void *data)
switch ((int) event.key.keysym.scancode)
{
case SDL_WEBOS_SCANCODE_BACK:
- /* Because webOS is sending DOWN/UP at the same time,
+ /* Because webOS is sending DOWN/UP at the same time,
we save this flag for later */
sdl_webos_special_keymap[sdl_webos_spkey_back] |= event.type == SDL_KEYDOWN;
code = RETROK_BACKSPACE;
diff --git a/input/input_driver.c b/input/input_driver.c
index f186853c89..c0581b3530 100644
--- a/input/input_driver.c
+++ b/input/input_driver.c
@@ -396,7 +396,7 @@ hid_driver_t *hid_drivers[] = {
};
#endif
-static input_driver_state_t input_driver_st; /* double alignment */
+static input_driver_state_t input_driver_st = {0}; /* double alignment */
/**************************************/
diff --git a/intl/msg_hash_us.c b/intl/msg_hash_us.c
index 8bbe22a594..c38c8881b0 100644
--- a/intl/msg_hash_us.c
+++ b/intl/msg_hash_us.c
@@ -518,7 +518,7 @@ static const char *menu_hash_to_str_us_label_enum(enum msg_hash_enums msg)
if ( msg <= MENU_ENUM_LABEL_INPUT_HOTKEY_BIND_END
&& msg >= MENU_ENUM_LABEL_INPUT_HOTKEY_BIND_BEGIN)
{
- static char hotkey_lbl[128];
+ static char hotkey_lbl[128] = {0};
unsigned idx = msg - MENU_ENUM_LABEL_INPUT_HOTKEY_BIND_BEGIN;
snprintf(hotkey_lbl, sizeof(hotkey_lbl), "input_hotkey_binds_%d", idx);
return hotkey_lbl;
diff --git a/libretro-common/streams/rzip_stream.c b/libretro-common/streams/rzip_stream.c
index e0d88dd13d..6f56fa66c6 100644
--- a/libretro-common/streams/rzip_stream.c
+++ b/libretro-common/streams/rzip_stream.c
@@ -97,7 +97,7 @@ static bool rzipstream_read_file_header(rzipstream_t *stream)
/* Check 'magic numbers' - first 8 bytes
* of header */
if (
- (length < RZIP_HEADER_SIZE) ||
+ (length < RZIP_HEADER_SIZE) ||
(header_bytes[0] != 35) || /* # */
(header_bytes[1] != 82) || /* R */
(header_bytes[2] != 90) || /* Z */
@@ -270,7 +270,7 @@ static bool rzipstream_init_stream(
stream->in_buf_size = stream->chunk_size;
stream->out_buf_size = stream->chunk_size * 2;
/* > Account for minimum zlib overhead
- * of 11 bytes... */
+ * of 11 bytes... */
stream->out_buf_size =
(stream->out_buf_size < (stream->in_buf_size + 11)) ?
stream->out_buf_size + 11 :
@@ -846,7 +846,7 @@ int rzipstream_putc(rzipstream_t *stream, int c)
* in the event of an error */
int rzipstream_vprintf(rzipstream_t *stream, const char* format, va_list args)
{
- static char buffer[8 * 1024];
+ static char buffer[8 * 1024] = {0};
int64_t num_chars = vsnprintf(buffer,
sizeof(buffer), format, args);
diff --git a/libretro-db/query.c b/libretro-db/query.c
index bf348b3bc0..e29be8e2da 100644
--- a/libretro-db/query.c
+++ b/libretro-db/query.c
@@ -211,10 +211,10 @@ static struct rmsgpack_dom_value query_func_between(
if (argc != 2)
return res;
- if ( argv[0].type != AT_VALUE
+ if ( argv[0].type != AT_VALUE
|| argv[1].type != AT_VALUE)
return res;
- if ( argv[0].a.value.type != RDT_INT
+ if ( argv[0].a.value.type != RDT_INT
|| argv[1].a.value.type != RDT_INT)
return res;
@@ -301,7 +301,7 @@ static void query_argument_free(struct argument *arg)
}
static struct buffer query_parse_integer(
- char *s, size_t len,
+ char *s, size_t len,
struct buffer buff,
struct rmsgpack_dom_value *value,
const char **error)
@@ -495,7 +495,7 @@ static struct buffer query_parse_value(
}
else if (
query_peek(buff, "b", STRLEN_CONST("b"))
- || query_peek(buff, "\"", STRLEN_CONST("\""))
+ || query_peek(buff, "\"", STRLEN_CONST("\""))
|| query_peek(buff, "'", STRLEN_CONST("'")))
buff = query_parse_string(s, len,
buff, value, error);
@@ -921,7 +921,7 @@ void *libretrodb_query_compile(libretrodb_t *db,
{
struct buffer buff;
/* TODO/FIXME - static local variable */
- static char tmp_error_buff [MAX_ERROR_LEN];
+ static char tmp_error_buff [MAX_ERROR_LEN] = {0};
struct query *q = (struct query*)malloc(sizeof(*q));
size_t error_buff_len = sizeof(tmp_error_buff);
diff --git a/menu/cbs/menu_cbs_ok.c b/menu/cbs/menu_cbs_ok.c
index ca4a7545ea..c9a9c9440a 100644
--- a/menu/cbs/menu_cbs_ok.c
+++ b/menu/cbs/menu_cbs_ok.c
@@ -5212,7 +5212,7 @@ void cb_generic_download(retro_task_t *task,
case MENU_ENUM_LABEL_CB_UPDATE_SHADERS_SLANG:
#if defined(HAVE_CG) || defined(HAVE_GLSL) || defined(HAVE_SLANG) || defined(HAVE_HLSL)
{
- static char shaderdir[DIR_MAX_LENGTH];
+ static char shaderdir[DIR_MAX_LENGTH] = {0};
const char *dirname = NULL;
const char *dir_video_shader = settings->paths.directory_video_shader;
diff --git a/network/wifi_driver.c b/network/wifi_driver.c
index 02f557eedf..70eed13eb1 100644
--- a/network/wifi_driver.c
+++ b/network/wifi_driver.c
@@ -1,245 +1,245 @@
-/* RetroArch - A frontend for libretro.
- * Copyright (C) 2010-2014 - Hans-Kristian Arntzen
- * Copyright (C) 2011-2021 - Daniel De Matteis
- *
- * RetroArch is free software: you can redistribute it and/or modify it under the terms
- * of the GNU General Public License as published by the Free Software Found-
- * ation, either version 3 of the License, or (at your option) any later version.
- *
- * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
- * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- * PURPOSE. See the GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along with RetroArch.
- * If not, see .
- */
-
-#include
-
-#ifdef HAVE_CONFIG_H
-#include "../config.h"
-#endif
-
-#include "../driver.h"
-#include "../list_special.h"
-#include "../retroarch.h"
-#include "../runloop.h"
-#include "../verbosity.h"
-
-#include "wifi_driver.h"
-
-wifi_driver_t wifi_null = {
- NULL, /* init */
- NULL, /* free */
- NULL, /* start */
- NULL, /* stop */
- NULL, /* enable */
- NULL, /* connection_info */
- NULL, /* scan */
- NULL, /* get_ssids */
- NULL, /* ssid_is_online */
- NULL, /* connect_ssid */
- NULL, /* disconnect_ssid */
- NULL, /* tether_start_stop */
- "null",
-};
-
-const wifi_driver_t *wifi_drivers[] = {
-#ifdef HAVE_LAKKA
- &wifi_connmanctl,
-#endif
-#ifdef HAVE_WIFI
- &wifi_nmcli,
-#endif
- &wifi_null,
- NULL,
-};
-
-static wifi_driver_state_t wifi_driver_st; /* double alignment */
-
-wifi_driver_state_t *wifi_state_get_ptr(void)
-{
- return &wifi_driver_st;
-}
-
-/**
- * config_get_wifi_driver_options:
- *
- * Get an enumerated list of all wifi driver names,
- * separated by '|'.
- *
- * Returns: string listing of all wifi driver names,
- * separated by '|'.
- **/
-const char* config_get_wifi_driver_options(void)
-{
- return char_list_new_special(STRING_LIST_WIFI_DRIVERS, NULL);
-}
-
-void driver_wifi_scan(void)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- wifi_st->drv->scan(wifi_st->data);
-}
-
-bool driver_wifi_enable(bool enabled)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->enable(wifi_st->data, enabled);
- return false;
-}
-
-bool driver_wifi_connection_info(wifi_network_info_t *netinfo)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->connection_info(wifi_st->data, netinfo);
- return false;
-}
-
-wifi_network_scan_t* driver_wifi_get_ssids(void)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->get_ssids(wifi_st->data);
- return NULL;
-}
-
-bool driver_wifi_ssid_is_online(unsigned i)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->ssid_is_online(wifi_st->data, i);
- return false;
-}
-
-bool driver_wifi_connect_ssid(const wifi_network_info_t* net)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->connect_ssid(wifi_st->data, net);
- return false;
-}
-
-bool driver_wifi_disconnect_ssid(const wifi_network_info_t* net)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- return wifi_st->drv->disconnect_ssid(wifi_st->data, net);
- return false;
-}
-
-void driver_wifi_tether_start_stop(bool start, char* configfile)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- if (wifi_st && wifi_st->drv)
- wifi_st->drv->tether_start_stop(wifi_st->data, start, configfile);
-}
-
-bool wifi_driver_ctl(enum rarch_wifi_ctl_state state, void *data)
-{
- wifi_driver_state_t *wifi_st = &wifi_driver_st;
- settings_t *settings = config_get_ptr();
-
- switch (state)
- {
- case RARCH_WIFI_CTL_DESTROY:
- wifi_st->active = false;
- wifi_st->drv = NULL;
- wifi_st->data = NULL;
- break;
- case RARCH_WIFI_CTL_SET_ACTIVE:
- wifi_st->active = true;
- break;
- case RARCH_WIFI_CTL_FIND_DRIVER:
- {
- const char *prefix = "wifi driver";
- int i = (int)driver_find_index(
- "wifi_driver",
- settings->arrays.wifi_driver);
-
- if (i >= 0)
- wifi_st->drv = (const wifi_driver_t*)wifi_drivers[i];
- else
- {
- if (verbosity_is_enabled())
- {
- unsigned d;
- RARCH_ERR("Couldn't find any %s named \"%s\"\n", prefix,
- settings->arrays.wifi_driver);
- RARCH_LOG_OUTPUT("Available %ss are:\n", prefix);
- for (d = 0; wifi_drivers[d]; d++)
- RARCH_LOG_OUTPUT("\t%s\n", wifi_drivers[d]->ident);
-
- RARCH_WARN("Going to default to first %s...\n", prefix);
- }
-
- wifi_st->drv = (const wifi_driver_t*)wifi_drivers[0];
-
- if (!wifi_st->drv)
- retroarch_fail(1, "find_wifi_driver()");
- }
- }
- break;
- case RARCH_WIFI_CTL_UNSET_ACTIVE:
- wifi_st->active = false;
- break;
- case RARCH_WIFI_CTL_IS_ACTIVE:
- return wifi_st->active;
- case RARCH_WIFI_CTL_DEINIT:
- if (wifi_st->data && wifi_st->drv)
- {
- if (wifi_st->drv->free)
- wifi_st->drv->free(wifi_st->data);
- }
-
- wifi_st->data = NULL;
- break;
- case RARCH_WIFI_CTL_STOP:
- if ( wifi_st->drv
- && wifi_st->drv->stop
- && wifi_st->data)
- wifi_st->drv->stop(wifi_st->data);
- break;
- case RARCH_WIFI_CTL_START:
- if ( wifi_st->drv
- && wifi_st->data
- && wifi_st->drv->start)
- {
- bool wifi_allow = settings->bools.wifi_allow;
- if (wifi_allow)
- return wifi_st->drv->start(wifi_st->data);
- }
- return false;
- case RARCH_WIFI_CTL_INIT:
- /* Resource leaks will follow if wifi is initialized twice. */
- if (wifi_st->data)
- return false;
-
- wifi_driver_ctl(RARCH_WIFI_CTL_FIND_DRIVER, NULL);
-
- if (wifi_st->drv && wifi_st->drv->init)
- {
- wifi_st->data = wifi_st->drv->init();
-
- if (wifi_st->data)
- {
- wifi_st->drv->enable(wifi_st->data,
- settings->bools.wifi_enabled);
- }
- else
- {
- RARCH_ERR("Failed to initialize wifi driver. Will continue without wifi.\n");
- wifi_driver_ctl(RARCH_WIFI_CTL_UNSET_ACTIVE, NULL);
- }
- }
-
- break;
- default:
- break;
- }
-
- return false;
-}
+/* RetroArch - A frontend for libretro.
+ * Copyright (C) 2010-2014 - Hans-Kristian Arntzen
+ * Copyright (C) 2011-2021 - Daniel De Matteis
+ *
+ * RetroArch is free software: you can redistribute it and/or modify it under the terms
+ * of the GNU General Public License as published by the Free Software Found-
+ * ation, either version 3 of the License, or (at your option) any later version.
+ *
+ * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with RetroArch.
+ * If not, see .
+ */
+
+#include
+
+#ifdef HAVE_CONFIG_H
+#include "../config.h"
+#endif
+
+#include "../driver.h"
+#include "../list_special.h"
+#include "../retroarch.h"
+#include "../runloop.h"
+#include "../verbosity.h"
+
+#include "wifi_driver.h"
+
+wifi_driver_t wifi_null = {
+ NULL, /* init */
+ NULL, /* free */
+ NULL, /* start */
+ NULL, /* stop */
+ NULL, /* enable */
+ NULL, /* connection_info */
+ NULL, /* scan */
+ NULL, /* get_ssids */
+ NULL, /* ssid_is_online */
+ NULL, /* connect_ssid */
+ NULL, /* disconnect_ssid */
+ NULL, /* tether_start_stop */
+ "null",
+};
+
+const wifi_driver_t *wifi_drivers[] = {
+#ifdef HAVE_LAKKA
+ &wifi_connmanctl,
+#endif
+#ifdef HAVE_WIFI
+ &wifi_nmcli,
+#endif
+ &wifi_null,
+ NULL,
+};
+
+static wifi_driver_state_t wifi_driver_st = {0}; /* double alignment */
+
+wifi_driver_state_t *wifi_state_get_ptr(void)
+{
+ return &wifi_driver_st;
+}
+
+/**
+ * config_get_wifi_driver_options:
+ *
+ * Get an enumerated list of all wifi driver names,
+ * separated by '|'.
+ *
+ * Returns: string listing of all wifi driver names,
+ * separated by '|'.
+ **/
+const char* config_get_wifi_driver_options(void)
+{
+ return char_list_new_special(STRING_LIST_WIFI_DRIVERS, NULL);
+}
+
+void driver_wifi_scan(void)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ wifi_st->drv->scan(wifi_st->data);
+}
+
+bool driver_wifi_enable(bool enabled)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->enable(wifi_st->data, enabled);
+ return false;
+}
+
+bool driver_wifi_connection_info(wifi_network_info_t *netinfo)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->connection_info(wifi_st->data, netinfo);
+ return false;
+}
+
+wifi_network_scan_t* driver_wifi_get_ssids(void)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->get_ssids(wifi_st->data);
+ return NULL;
+}
+
+bool driver_wifi_ssid_is_online(unsigned i)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->ssid_is_online(wifi_st->data, i);
+ return false;
+}
+
+bool driver_wifi_connect_ssid(const wifi_network_info_t* net)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->connect_ssid(wifi_st->data, net);
+ return false;
+}
+
+bool driver_wifi_disconnect_ssid(const wifi_network_info_t* net)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ return wifi_st->drv->disconnect_ssid(wifi_st->data, net);
+ return false;
+}
+
+void driver_wifi_tether_start_stop(bool start, char* configfile)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ if (wifi_st && wifi_st->drv)
+ wifi_st->drv->tether_start_stop(wifi_st->data, start, configfile);
+}
+
+bool wifi_driver_ctl(enum rarch_wifi_ctl_state state, void *data)
+{
+ wifi_driver_state_t *wifi_st = &wifi_driver_st;
+ settings_t *settings = config_get_ptr();
+
+ switch (state)
+ {
+ case RARCH_WIFI_CTL_DESTROY:
+ wifi_st->active = false;
+ wifi_st->drv = NULL;
+ wifi_st->data = NULL;
+ break;
+ case RARCH_WIFI_CTL_SET_ACTIVE:
+ wifi_st->active = true;
+ break;
+ case RARCH_WIFI_CTL_FIND_DRIVER:
+ {
+ const char *prefix = "wifi driver";
+ int i = (int)driver_find_index(
+ "wifi_driver",
+ settings->arrays.wifi_driver);
+
+ if (i >= 0)
+ wifi_st->drv = (const wifi_driver_t*)wifi_drivers[i];
+ else
+ {
+ if (verbosity_is_enabled())
+ {
+ unsigned d;
+ RARCH_ERR("Couldn't find any %s named \"%s\"\n", prefix,
+ settings->arrays.wifi_driver);
+ RARCH_LOG_OUTPUT("Available %ss are:\n", prefix);
+ for (d = 0; wifi_drivers[d]; d++)
+ RARCH_LOG_OUTPUT("\t%s\n", wifi_drivers[d]->ident);
+
+ RARCH_WARN("Going to default to first %s...\n", prefix);
+ }
+
+ wifi_st->drv = (const wifi_driver_t*)wifi_drivers[0];
+
+ if (!wifi_st->drv)
+ retroarch_fail(1, "find_wifi_driver()");
+ }
+ }
+ break;
+ case RARCH_WIFI_CTL_UNSET_ACTIVE:
+ wifi_st->active = false;
+ break;
+ case RARCH_WIFI_CTL_IS_ACTIVE:
+ return wifi_st->active;
+ case RARCH_WIFI_CTL_DEINIT:
+ if (wifi_st->data && wifi_st->drv)
+ {
+ if (wifi_st->drv->free)
+ wifi_st->drv->free(wifi_st->data);
+ }
+
+ wifi_st->data = NULL;
+ break;
+ case RARCH_WIFI_CTL_STOP:
+ if ( wifi_st->drv
+ && wifi_st->drv->stop
+ && wifi_st->data)
+ wifi_st->drv->stop(wifi_st->data);
+ break;
+ case RARCH_WIFI_CTL_START:
+ if ( wifi_st->drv
+ && wifi_st->data
+ && wifi_st->drv->start)
+ {
+ bool wifi_allow = settings->bools.wifi_allow;
+ if (wifi_allow)
+ return wifi_st->drv->start(wifi_st->data);
+ }
+ return false;
+ case RARCH_WIFI_CTL_INIT:
+ /* Resource leaks will follow if wifi is initialized twice. */
+ if (wifi_st->data)
+ return false;
+
+ wifi_driver_ctl(RARCH_WIFI_CTL_FIND_DRIVER, NULL);
+
+ if (wifi_st->drv && wifi_st->drv->init)
+ {
+ wifi_st->data = wifi_st->drv->init();
+
+ if (wifi_st->data)
+ {
+ wifi_st->drv->enable(wifi_st->data,
+ settings->bools.wifi_enabled);
+ }
+ else
+ {
+ RARCH_ERR("Failed to initialize wifi driver. Will continue without wifi.\n");
+ wifi_driver_ctl(RARCH_WIFI_CTL_UNSET_ACTIVE, NULL);
+ }
+ }
+
+ break;
+ default:
+ break;
+ }
+
+ return false;
+}
diff --git a/playlist.c b/playlist.c
index 749e8fdddb..592b065d13 100644
--- a/playlist.c
+++ b/playlist.c
@@ -1334,7 +1334,7 @@ bool playlist_push(playlist_t *playlist,
if (string_is_empty(core_name))
{
- static char base_path[NAME_MAX_LENGTH];
+ static char base_path[NAME_MAX_LENGTH] = {0};
fill_pathname_base(base_path, real_core_path, sizeof(base_path));
path_remove_extension(base_path);
diff --git a/record/record_driver.c b/record/record_driver.c
index a5cf9ae959..63ccd8d0e1 100644
--- a/record/record_driver.c
+++ b/record/record_driver.c
@@ -34,7 +34,7 @@
#include "drivers/record_ffmpeg.h"
#include "drivers/record_wav.h"
-static recording_state_t recording_state;
+static recording_state_t recording_state = {0};
static const record_driver_t record_null = {
NULL, /* new */
diff --git a/retroarch.c b/retroarch.c
index 91bd7d58dc..f5bd2da2b5 100644
--- a/retroarch.c
+++ b/retroarch.c
@@ -330,14 +330,14 @@ struct rarch_state
void libnx_apply_overclock(void);
#endif
-static struct rarch_state rarch_st;
+static struct rarch_state rarch_st = {0};
#ifdef HAVE_THREAD_STORAGE
static const void *MAGIC_POINTER = (void*)(uintptr_t)0x0DEFACED;
#endif
-static access_state_t access_state_st;
-static struct global global_driver_st; /* retro_time_t alignment */
+static access_state_t access_state_st = {0};
+static struct global global_driver_st = {0}; /* retro_time_t alignment */
static void retro_frame_null(const void *data, unsigned width,
unsigned height, size_t pitch) { }
@@ -361,7 +361,7 @@ static const location_driver_t *location_drivers[] = {
NULL,
};
-static location_driver_state_t location_driver_st;
+static location_driver_state_t location_driver_st = {0};
location_driver_state_t *location_state_get_ptr(void)
{
diff --git a/runloop.c b/runloop.c
index 4b77341cb7..0e4bf6b963 100644
--- a/runloop.c
+++ b/runloop.c
@@ -322,7 +322,7 @@
#define PERF_LOG_FMT "[PERF]: Avg (%s): %llu ticks, %llu runs.\n"
#endif
-static runloop_state_t runloop_state;
+static runloop_state_t runloop_state = {0};
/* GLOBAL POINTER GETTERS */
runloop_state_t *runloop_state_get_ptr(void)
@@ -6740,7 +6740,7 @@ static enum runloop_state_enum runloop_check_state(
if (settings->bools.video_shader_watch_files)
{
- static rarch_timer_t timer;
+ static rarch_timer_t timer = {0};
static bool need_to_apply = false;
if (video_shader_check_for_changes())
diff --git a/ui/drivers/ui_qt.cpp b/ui/drivers/ui_qt.cpp
index 128c8dd39c..ca5b3363b7 100644
--- a/ui/drivers/ui_qt.cpp
+++ b/ui/drivers/ui_qt.cpp
@@ -990,7 +990,7 @@ static unsigned char invader_png[] = {
};
static unsigned int invader_png_len = 4008;
-static ui_window_qt_t ui_window;
+static ui_window_qt_t ui_window = {0};
static const QPixmap getInvader(void)
{
diff --git a/ui/ui_companion_driver.c b/ui/ui_companion_driver.c
index da02c1119f..649891188b 100644
--- a/ui/ui_companion_driver.c
+++ b/ui/ui_companion_driver.c
@@ -1,259 +1,259 @@
-/* RetroArch - A frontend for libretro.
- * Copyright (C) 2010-2014 - Hans-Kristian Arntzen
- * Copyright (C) 2011-2021 - Daniel De Matteis
- *
- * RetroArch is free software: you can redistribute it and/or modify it under the terms
- * of the GNU General Public License as published by the Free Software Found-
- * ation, either version 3 of the License, or (at your option) any later version.
- *
- * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
- * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- * PURPOSE. See the GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License along with RetroArch.
- * If not, see .
- */
-
-#include
-
-#ifdef HAVE_CONFIG_H
-#include "../config.h"
-#endif
-
-#include "../list_special.h"
-#include "../retroarch.h"
-#include "../runloop.h"
-#include "../verbosity.h"
-
-#include "ui_companion_driver.h"
-
-static ui_companion_driver_t ui_companion_null = {
- NULL, /* init */
- NULL, /* deinit */
- NULL, /* toggle */
- NULL, /* event_command */
- NULL, /* notify_refresh */
- NULL, /* msg_queue_push */
- NULL, /* render_messagebox */
- NULL, /* get_main_window */
- NULL, /* log_msg */
- NULL, /* is_active */
- NULL, /* get_app_icons */
- NULL, /* set_app_icon */
- NULL, /* get_app_icon_texture */
- NULL, /* browser_window */
- NULL, /* msg_window */
- NULL, /* window */
- NULL, /* application */
- "null", /* ident */
-};
-
-static const ui_companion_driver_t *ui_companion_drivers[] = {
-#if defined(_WIN32) && !defined(_XBOX) && !defined(__WINRT__)
- &ui_companion_win32,
-#endif
-#if defined(OSX)
- &ui_companion_cocoa,
-#endif
-#if defined(IOS)
- &ui_companion_cocoatouch,
-#endif
- &ui_companion_null,
- NULL
-};
-
-
-static uico_driver_state_t uico_driver_st; /* double alignment */
-
-uico_driver_state_t *uico_state_get_ptr(void)
-{
- return &uico_driver_st;
-}
-
-uint8_t ui_companion_get_flags(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- if (!uico_st)
- return 0;
- return uico_st->flags;
-}
-
-void ui_companion_event_command(enum event_command action)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (ui && ui->event_command)
- ui->event_command(uico_st->data, action);
-#ifdef HAVE_QT
- if (ui_companion_qt.toggle && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
- ui_companion_qt.event_command(uico_st->qt_data, action);
-#endif
-}
-
-void ui_companion_driver_deinit(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
-
- if (!ui)
- return;
- if (ui->deinit)
- ui->deinit(uico_st->data);
-
-#ifdef HAVE_QT
- if (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)
- {
- ui_companion_qt.deinit(uico_st->qt_data);
- uico_st->qt_data = NULL;
- }
-#endif
- uico_st->data = NULL;
-}
-
-void ui_companion_driver_toggle(
- bool desktop_menu_enable,
- bool ui_companion_toggle,
- bool force)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- if (uico_st && uico_st->drv && uico_st->drv->toggle)
- uico_st->drv->toggle(uico_st->data, false);
-
-#ifdef HAVE_QT
- if (desktop_menu_enable)
- {
- if ((ui_companion_toggle || force) && (!(uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)))
- {
- uico_st->qt_data = ui_companion_qt.init();
- uico_st->flags |= UICO_ST_FLAG_QT_IS_INITED;
- }
-
- if (ui_companion_qt.toggle && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
- ui_companion_qt.toggle(uico_st->qt_data, force);
- }
-#endif
-}
-
-void ui_companion_driver_init_first(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- settings_t *settings = config_get_ptr();
-#ifdef HAVE_QT
- bool desktop_menu_enable = settings->bools.desktop_menu_enable;
- bool ui_companion_toggle = settings->bools.ui_companion_toggle;
-
- if (desktop_menu_enable && ui_companion_toggle)
- {
- uico_st->qt_data = ui_companion_qt.init();
- uico_st->flags |= UICO_ST_FLAG_QT_IS_INITED;
- }
-#else
- bool desktop_menu_enable = false;
- bool ui_companion_toggle = false;
-#endif
- unsigned ui_companion_start_on_boot =
- settings->bools.ui_companion_start_on_boot;
- uico_st->drv = (ui_companion_driver_t*)ui_companion_drivers[0];
-
- if (!uico_st->drv)
- return;
- if (!ui_companion_start_on_boot)
- return;
- if (uico_st->drv->init)
- uico_st->data = uico_st->drv->init();
-
- ui_companion_driver_toggle(desktop_menu_enable,
- ui_companion_toggle, false);
-}
-
-void ui_companion_driver_notify_refresh(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (!ui)
- return;
- if (ui->notify_refresh)
- ui->notify_refresh(uico_st->data);
-
-#ifdef HAVE_QT
- if (config_get_ptr()->bools.desktop_menu_enable)
- if (ui_companion_qt.notify_refresh && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
- ui_companion_qt.notify_refresh(uico_st->qt_data);
-#endif
-}
-
-const ui_msg_window_t *ui_companion_driver_get_msg_window_ptr(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (ui)
- return ui->msg_window;
- return NULL;
-}
-
-const ui_window_t *ui_companion_driver_get_window_ptr(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (ui)
- return ui->window;
- return NULL;
-}
-
-const ui_browser_window_t *ui_companion_driver_get_browser_window_ptr(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (ui)
- return ui->browser_window;
- return NULL;
-}
-
-void ui_companion_driver_msg_queue_push(
- const char *msg, unsigned priority,
- unsigned duration, bool flush)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
-
- if (ui && ui->msg_queue_push)
- ui->msg_queue_push(uico_st->data, msg, priority, duration, flush);
-
-#ifdef HAVE_QT
- if (config_get_ptr()->bools.desktop_menu_enable)
- if (ui_companion_qt.msg_queue_push && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
- ui_companion_qt.msg_queue_push(
- uico_st->qt_data,
- msg, priority, duration, flush);
-#endif
-}
-
-void *ui_companion_driver_get_main_window(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (!ui || !ui->get_main_window)
- return NULL;
- return ui->get_main_window(uico_st->data);
-}
-
-const char *ui_companion_driver_get_ident(void)
-{
- uico_driver_state_t *uico_st = &uico_driver_st;
- const ui_companion_driver_t *ui = uico_st->drv;
- if (ui)
- return ui->ident;
- return "null";
-}
-
-void ui_companion_driver_log_msg(const char *msg)
-{
-#ifdef HAVE_QT
- uico_driver_state_t *uico_st= &uico_driver_st;
- bool window_is_active = uico_st->qt_data && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)
- && ui_companion_qt.is_active(uico_st->qt_data);
- if (config_get_ptr()->bools.desktop_menu_enable)
- if (window_is_active)
- ui_companion_qt.log_msg(uico_st->qt_data, msg);
-#endif
-}
+/* RetroArch - A frontend for libretro.
+ * Copyright (C) 2010-2014 - Hans-Kristian Arntzen
+ * Copyright (C) 2011-2021 - Daniel De Matteis
+ *
+ * RetroArch is free software: you can redistribute it and/or modify it under the terms
+ * of the GNU General Public License as published by the Free Software Found-
+ * ation, either version 3 of the License, or (at your option) any later version.
+ *
+ * RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with RetroArch.
+ * If not, see .
+ */
+
+#include
+
+#ifdef HAVE_CONFIG_H
+#include "../config.h"
+#endif
+
+#include "../list_special.h"
+#include "../retroarch.h"
+#include "../runloop.h"
+#include "../verbosity.h"
+
+#include "ui_companion_driver.h"
+
+static ui_companion_driver_t ui_companion_null = {
+ NULL, /* init */
+ NULL, /* deinit */
+ NULL, /* toggle */
+ NULL, /* event_command */
+ NULL, /* notify_refresh */
+ NULL, /* msg_queue_push */
+ NULL, /* render_messagebox */
+ NULL, /* get_main_window */
+ NULL, /* log_msg */
+ NULL, /* is_active */
+ NULL, /* get_app_icons */
+ NULL, /* set_app_icon */
+ NULL, /* get_app_icon_texture */
+ NULL, /* browser_window */
+ NULL, /* msg_window */
+ NULL, /* window */
+ NULL, /* application */
+ "null", /* ident */
+};
+
+static const ui_companion_driver_t *ui_companion_drivers[] = {
+#if defined(_WIN32) && !defined(_XBOX) && !defined(__WINRT__)
+ &ui_companion_win32,
+#endif
+#if defined(OSX)
+ &ui_companion_cocoa,
+#endif
+#if defined(IOS)
+ &ui_companion_cocoatouch,
+#endif
+ &ui_companion_null,
+ NULL
+};
+
+
+static uico_driver_state_t uico_driver_st = {0}; /* double alignment */
+
+uico_driver_state_t *uico_state_get_ptr(void)
+{
+ return &uico_driver_st;
+}
+
+uint8_t ui_companion_get_flags(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ if (!uico_st)
+ return 0;
+ return uico_st->flags;
+}
+
+void ui_companion_event_command(enum event_command action)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (ui && ui->event_command)
+ ui->event_command(uico_st->data, action);
+#ifdef HAVE_QT
+ if (ui_companion_qt.toggle && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
+ ui_companion_qt.event_command(uico_st->qt_data, action);
+#endif
+}
+
+void ui_companion_driver_deinit(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+
+ if (!ui)
+ return;
+ if (ui->deinit)
+ ui->deinit(uico_st->data);
+
+#ifdef HAVE_QT
+ if (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)
+ {
+ ui_companion_qt.deinit(uico_st->qt_data);
+ uico_st->qt_data = NULL;
+ }
+#endif
+ uico_st->data = NULL;
+}
+
+void ui_companion_driver_toggle(
+ bool desktop_menu_enable,
+ bool ui_companion_toggle,
+ bool force)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ if (uico_st && uico_st->drv && uico_st->drv->toggle)
+ uico_st->drv->toggle(uico_st->data, false);
+
+#ifdef HAVE_QT
+ if (desktop_menu_enable)
+ {
+ if ((ui_companion_toggle || force) && (!(uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)))
+ {
+ uico_st->qt_data = ui_companion_qt.init();
+ uico_st->flags |= UICO_ST_FLAG_QT_IS_INITED;
+ }
+
+ if (ui_companion_qt.toggle && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
+ ui_companion_qt.toggle(uico_st->qt_data, force);
+ }
+#endif
+}
+
+void ui_companion_driver_init_first(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ settings_t *settings = config_get_ptr();
+#ifdef HAVE_QT
+ bool desktop_menu_enable = settings->bools.desktop_menu_enable;
+ bool ui_companion_toggle = settings->bools.ui_companion_toggle;
+
+ if (desktop_menu_enable && ui_companion_toggle)
+ {
+ uico_st->qt_data = ui_companion_qt.init();
+ uico_st->flags |= UICO_ST_FLAG_QT_IS_INITED;
+ }
+#else
+ bool desktop_menu_enable = false;
+ bool ui_companion_toggle = false;
+#endif
+ unsigned ui_companion_start_on_boot =
+ settings->bools.ui_companion_start_on_boot;
+ uico_st->drv = (ui_companion_driver_t*)ui_companion_drivers[0];
+
+ if (!uico_st->drv)
+ return;
+ if (!ui_companion_start_on_boot)
+ return;
+ if (uico_st->drv->init)
+ uico_st->data = uico_st->drv->init();
+
+ ui_companion_driver_toggle(desktop_menu_enable,
+ ui_companion_toggle, false);
+}
+
+void ui_companion_driver_notify_refresh(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (!ui)
+ return;
+ if (ui->notify_refresh)
+ ui->notify_refresh(uico_st->data);
+
+#ifdef HAVE_QT
+ if (config_get_ptr()->bools.desktop_menu_enable)
+ if (ui_companion_qt.notify_refresh && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
+ ui_companion_qt.notify_refresh(uico_st->qt_data);
+#endif
+}
+
+const ui_msg_window_t *ui_companion_driver_get_msg_window_ptr(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (ui)
+ return ui->msg_window;
+ return NULL;
+}
+
+const ui_window_t *ui_companion_driver_get_window_ptr(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (ui)
+ return ui->window;
+ return NULL;
+}
+
+const ui_browser_window_t *ui_companion_driver_get_browser_window_ptr(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (ui)
+ return ui->browser_window;
+ return NULL;
+}
+
+void ui_companion_driver_msg_queue_push(
+ const char *msg, unsigned priority,
+ unsigned duration, bool flush)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+
+ if (ui && ui->msg_queue_push)
+ ui->msg_queue_push(uico_st->data, msg, priority, duration, flush);
+
+#ifdef HAVE_QT
+ if (config_get_ptr()->bools.desktop_menu_enable)
+ if (ui_companion_qt.msg_queue_push && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED))
+ ui_companion_qt.msg_queue_push(
+ uico_st->qt_data,
+ msg, priority, duration, flush);
+#endif
+}
+
+void *ui_companion_driver_get_main_window(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (!ui || !ui->get_main_window)
+ return NULL;
+ return ui->get_main_window(uico_st->data);
+}
+
+const char *ui_companion_driver_get_ident(void)
+{
+ uico_driver_state_t *uico_st = &uico_driver_st;
+ const ui_companion_driver_t *ui = uico_st->drv;
+ if (ui)
+ return ui->ident;
+ return "null";
+}
+
+void ui_companion_driver_log_msg(const char *msg)
+{
+#ifdef HAVE_QT
+ uico_driver_state_t *uico_st= &uico_driver_st;
+ bool window_is_active = uico_st->qt_data && (uico_st->flags & UICO_ST_FLAG_QT_IS_INITED)
+ && ui_companion_qt.is_active(uico_st->qt_data);
+ if (config_get_ptr()->bools.desktop_menu_enable)
+ if (window_is_active)
+ ui_companion_qt.log_msg(uico_st->qt_data, msg);
+#endif
+}
diff --git a/verbosity.c b/verbosity.c
index cedad2f0e5..f3ce94a5e5 100644
--- a/verbosity.c
+++ b/verbosity.c
@@ -457,7 +457,7 @@ void rarch_log_file_init(
char log_file_path[PATH_MAX_LENGTH];
verbosity_state_t *g_verbosity = &main_verbosity_st;
static bool log_file_created = false;
- static char timestamped_log_file_name[64];
+ static char timestamped_log_file_name[64] = {0};
bool logging_to_file = g_verbosity->initialized;