diff --git a/Makefile.ps2 b/Makefile.ps2
index b84aa8ac33..8dcb473248 100644
--- a/Makefile.ps2
+++ b/Makefile.ps2
@@ -40,7 +40,7 @@ RARCH_DEFINES += -DHAVE_GRIFFIN=1 -DRARCH_INTERNAL -DRARCH_CONSOLE -DHAVE_MENU -
LIBDIR =
LDFLAGS += -L$(PS2SDK)/ports/lib -L$(PS2DEV)/gsKit/lib -L$(PS2SDK)/ee/lib -L.
-LIBS += -lretro_ps2 -lgskit -ldmakit -laudsrv -lpad -lmc -lhdd -lsdl -lfileXio -lpatches -lpoweroff
+LIBS += -lretro_ps2 -lgskit -ldmakit -lgskit_toolkit -laudsrv -lpad -lmc -lhdd -lsdl -lfileXio -lpatches -lpoweroff
#IRX modules
# IRX modules - modules have to be in IRX_DIR
@@ -73,6 +73,7 @@ EE_OBJS += ps2/compat_files/compat_ctype.o ps2/compat_files/time.o
EE_OBJS += griffin/griffin.o
EE_CFLAGS = $(CFLAGS)
+EE_CXXFLAGS = $(CFLAGS)
EE_LDFLAGS = $(LDFLAGS)
EE_LIBS = $(LIBS)
EE_ASFLAGS = $(ASFLAGS)
diff --git a/gfx/drivers/ps2_gfx.c b/gfx/drivers/ps2_gfx.c
index fc3d29bf62..481d765e28 100644
--- a/gfx/drivers/ps2_gfx.c
+++ b/gfx/drivers/ps2_gfx.c
@@ -196,6 +196,9 @@ static void *ps2_gfx_init(const video_info_t *video,
return NULL;
init_ps2_video(ps2);
+ if (video->font_enable) {
+ font_driver_init_osd(ps2, false, video->is_threaded, FONT_DRIVER_RENDER_PS2);
+ }
ps2->rgb32 = video->rgb32;
ps2->fullscreen = video->fullscreen;
ps2->core_filter = video->smooth ? GS_FILTER_LINEAR : GS_FILTER_NEAREST;
@@ -223,7 +226,6 @@ static bool ps2_gfx_frame(void *data, const void *frame,
static float fps = 0.0;
#endif
ps2_video_t *ps2 = (ps2_video_t*)data;
- bool texture_empty = true;
if (!width || !height)
return false;
@@ -241,11 +243,25 @@ static bool ps2_gfx_frame(void *data, const void *frame,
prim_texture(ps2->gsGlobal, ps2->coreTexture, 1, ps2->force_aspect);
}
- texture_empty = !ps2->menuTexture->Width || !ps2->menuTexture->Height;
- if (ps2->menuVisible && !texture_empty) {
- vram_alloc(ps2->gsGlobal, ps2->menuTexture);
- gsKit_texture_upload(ps2->gsGlobal, ps2->menuTexture);
- prim_texture(ps2->gsGlobal, ps2->menuTexture, 2, ps2->fullscreen);
+ if (ps2->menuVisible) {
+ bool texture_empty = !ps2->menuTexture->Width || !ps2->menuTexture->Height;
+ if (!texture_empty) {
+ vram_alloc(ps2->gsGlobal, ps2->menuTexture);
+ gsKit_texture_upload(ps2->gsGlobal, ps2->menuTexture);
+ prim_texture(ps2->gsGlobal, ps2->menuTexture, 2, ps2->fullscreen);
+ }
+ } else if (video_info->statistics_show) {
+ struct font_params *osd_params = (struct font_params*)
+ &video_info->osd_stat_params;
+
+ if (osd_params) {
+ font_driver_render_msg(video_info, NULL, video_info->stat_text,
+ (const struct font_params*)&video_info->osd_stat_params);
+ }
+ }
+
+ if(!string_is_empty(msg)) {
+ font_driver_render_msg(video_info, NULL, msg, NULL);
}
gsKit_sync_flip(ps2->gsGlobal);
@@ -292,6 +308,8 @@ static void ps2_gfx_free(void *data)
gsKit_clear(ps2->gsGlobal, GS_BLACK);
gsKit_vram_clear(ps2->gsGlobal);
+ font_driver_free_osd();
+
deinitTexture(ps2->menuTexture);
deinitTexture(ps2->coreTexture);
@@ -364,6 +382,14 @@ static void ps2_set_texture_enable(void *data, bool enable, bool fullscreen)
ps2->fullscreen = fullscreen;
}
+static void ps2_set_osd_msg(void *data,
+ video_frame_info_t *video_info,
+ const char *msg,
+ const void *params, void *font)
+{
+ font_driver_render_msg(video_info, font, msg, params);
+}
+
static const video_poke_interface_t ps2_poke_interface = {
NULL, /* get_flags */
NULL, /* set_coords */
@@ -382,7 +408,7 @@ static const video_poke_interface_t ps2_poke_interface = {
ps2_apply_state_changes,
ps2_set_texture_frame,
ps2_set_texture_enable,
- NULL, /* set_osd_msg */
+ ps2_set_osd_msg, /* set_osd_msg */
NULL, /* show_mouse */
NULL, /* grab_mouse_toggle */
NULL, /* get_current_shader */
diff --git a/gfx/drivers_font/ps2_font.c b/gfx/drivers_font/ps2_font.c
new file mode 100644
index 0000000000..2b96346a4d
--- /dev/null
+++ b/gfx/drivers_font/ps2_font.c
@@ -0,0 +1,126 @@
+/* RetroArch - A frontend for libretro.
+ * Copyright (C) 2010-2019 - Francisco Javier Trujillo Mata
+ *
+ * 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
+#include
+#include
+
+#include "../font_driver.h"
+
+#define FONTM_VRAM_SIZE 4096
+#define FONTM_TEXTURE_COLOR GS_SETREG_RGBAQ(0x80,0x80,0x80,0x80,0x00)
+#define FONTM_TEXTURE_WIDTH 52
+#define FONTM_TEXTURE_HEIGHT 832
+#define FONTM_TEXTURE_SPACING 1.0f
+#define FONTM_TEXTURE_SCALED 0.5f
+#define FONTM_TEXTURE_LEFT_MARGIN 0
+#define FONTM_TEXTURE_BOTTOM_MARGIN 15
+#define FONTM_TEXTURE_ZPOSITION 3
+
+typedef struct ps2_font_info
+{
+ GSGLOBAL *gsGlobal;
+ GSFONTM *gsFontM;
+} ps2_font_info_t;
+
+/* Copied from GSKIT FONTM CLUT
+ FONTM Textures are GS_PSM_T4, and need a 16x16 CLUT
+ This is a greyscale ramp CLUT, with linear alpha. */
+static u32 gsKit_fontm_clut[16] = { 0x00000000, 0x11111111, 0x22222222, 0x33333333, \
+ 0x44444444, 0x55555555, 0x66666666, 0x77777777, \
+ 0x80888888, 0x80999999, 0x80AAAAAA, 0x80BBBBBB, \
+ 0x80CCCCCC, 0x80DDDDDD, 0x80EEEEEE, 0x80FFFFFF };
+
+static void ps2_prepare_font(GSGLOBAL *gsGlobal, GSFONTM *gsFontM) {
+ if(gsKit_fontm_unpack(gsFontM) == 0) {
+ gsFontM->Texture->Width = FONTM_TEXTURE_WIDTH;
+ gsFontM->Texture->Height = FONTM_TEXTURE_HEIGHT;
+ gsFontM->Texture->PSM = GS_PSM_T4;
+ gsFontM->Texture->ClutPSM = GS_PSM_CT32;
+ gsFontM->Texture->Filter = GS_FILTER_LINEAR;
+ gsKit_setup_tbw(gsFontM->Texture);
+ }
+}
+
+static void ps2_upload_font(GSGLOBAL *gsGlobal, GSFONTM *gsFontM) {
+ int pgindx;
+ int TexSize = gsKit_texture_size(gsFontM->Texture->Width, gsFontM->Texture->Height, gsFontM->Texture->PSM);
+
+ free(gsFontM->Texture->VramClut);
+ gsFontM->Texture->VramClut = gsKit_vram_alloc(gsGlobal, FONTM_VRAM_SIZE, GSKIT_ALLOC_USERBUFFER);
+
+ for (pgindx = 0; pgindx < GS_FONTM_PAGE_COUNT; ++pgindx) {
+ free(gsFontM->Vram[pgindx]);
+ gsFontM->Vram[pgindx] = gsKit_vram_alloc(gsGlobal, TexSize, GSKIT_ALLOC_USERBUFFER);
+ gsFontM->LastPage[pgindx] = (u32) -1;
+ }
+
+ gsFontM->Texture->Vram = gsFontM->Vram[0];
+ gsFontM->VramIdx = 0;
+ gsFontM->Spacing = FONTM_TEXTURE_SPACING;
+ gsFontM->Align = GSKIT_FALIGN_LEFT;
+
+ gsFontM->Texture->Clut = memalign(GS_VRAM_TBWALIGN_CLUT, GS_VRAM_TBWALIGN);
+ memcpy(gsFontM->Texture->Clut, gsKit_fontm_clut, GS_VRAM_TBWALIGN);
+ gsKit_texture_send(gsFontM->Texture->Clut, 8, 2, gsFontM->Texture->VramClut, gsFontM->Texture->ClutPSM, 1, GS_CLUT_PALLETE);
+ free(gsFontM->Texture->Clut);
+}
+
+static void *ps2_font_init_font(void *gl_data, const char *font_path,
+ float font_size, bool is_threaded)
+{
+ ps2_font_info_t *ps2 = (ps2_font_info_t*)calloc(1, sizeof(ps2_font_info_t));
+ ps2_video_t *ps2_video = (ps2_video_t *)gl_data;
+ ps2->gsGlobal = ps2_video->gsGlobal;
+ ps2->gsFontM = gsKit_init_fontm();
+
+ ps2_prepare_font(ps2->gsGlobal, ps2->gsFontM);
+
+ return ps2;
+}
+
+static void ps2_font_free_font(void *data, bool is_threaded)
+{
+ ps2_font_info_t *ps2 = (ps2_font_info_t *)data;
+ free(ps2->gsFontM);
+ free(ps2);
+}
+
+static void ps2_font_render_msg(
+ video_frame_info_t *video_info,
+ void *data, const char *msg,
+ const struct font_params *params)
+{
+ ps2_font_info_t *ps2 = (ps2_font_info_t *)data;
+
+ if (ps2) {
+ int x = FONTM_TEXTURE_LEFT_MARGIN;
+ int y = ps2->gsGlobal->Height - FONTM_TEXTURE_BOTTOM_MARGIN;
+ ps2_upload_font(ps2->gsGlobal, ps2->gsFontM);
+ gsKit_fontm_print_scaled(ps2->gsGlobal, ps2->gsFontM, x, y, FONTM_TEXTURE_ZPOSITION,
+ FONTM_TEXTURE_SCALED , FONTM_TEXTURE_COLOR, msg);
+ }
+}
+
+font_renderer_t ps2_font = {
+ ps2_font_init_font,
+ ps2_font_free_font,
+ ps2_font_render_msg,
+ "PS2 font",
+ NULL, /* get_glyph */
+ NULL, /* bind_block */
+ NULL, /* flush */
+ NULL, /* get_message_width */
+};
diff --git a/gfx/font_driver.c b/gfx/font_driver.c
index 8eaf1d2447..4b094e2deb 100644
--- a/gfx/font_driver.c
+++ b/gfx/font_driver.c
@@ -464,6 +464,36 @@ static bool d3d12_font_init_first(
}
#endif
+#ifdef PS2
+static const font_renderer_t *ps2_font_backends[] = {
+ &ps2_font
+};
+
+static bool ps2_font_init_first(
+ const void **font_driver, void **font_handle,
+ void *video_data, const char *font_path,
+ float font_size, bool is_threaded)
+{
+ unsigned i;
+
+ for (i = 0; ps2_font_backends[i]; i++)
+ {
+ void *data = ps2_font_backends[i]->init(
+ video_data, font_path, font_size,
+ is_threaded);
+
+ if (!data)
+ continue;
+
+ *font_driver = ps2_font_backends[i];
+ *font_handle = data;
+ return true;
+ }
+
+ return false;
+}
+#endif
+
#ifdef HAVE_VITA2D
static const font_renderer_t *vita2d_font_backends[] = {
&vita2d_vita_font
@@ -641,6 +671,11 @@ static bool font_init_first(
return vita2d_font_init_first(font_driver, font_handle,
video_data, font_path, font_size, is_threaded);
#endif
+#ifdef PS2
+ case FONT_DRIVER_RENDER_PS2:
+ return ps2_font_init_first(font_driver, font_handle,
+ video_data, font_path, font_size, is_threaded);
+#endif
#ifdef _3DS
case FONT_DRIVER_RENDER_CTR:
return ctr_font_init_first(font_driver, font_handle,
diff --git a/gfx/font_driver.h b/gfx/font_driver.h
index 03f08c6d54..499c0a16e1 100644
--- a/gfx/font_driver.h
+++ b/gfx/font_driver.h
@@ -161,6 +161,7 @@ extern font_renderer_t libdbg_font;
extern font_renderer_t d3d_xbox360_font;
extern font_renderer_t d3d_xdk1_font;
extern font_renderer_t d3d_win32_font;
+extern font_renderer_t ps2_font;
extern font_renderer_t vita2d_vita_font;
extern font_renderer_t ctr_font;
extern font_renderer_t wiiu_font;
diff --git a/gfx/video_defines.h b/gfx/video_defines.h
index 7633846589..1bef08c767 100644
--- a/gfx/video_defines.h
+++ b/gfx/video_defines.h
@@ -88,6 +88,7 @@ enum font_driver_render_api
FONT_DRIVER_RENDER_D3D10_API,
FONT_DRIVER_RENDER_D3D11_API,
FONT_DRIVER_RENDER_D3D12_API,
+ FONT_DRIVER_RENDER_PS2,
FONT_DRIVER_RENDER_VITA2D,
FONT_DRIVER_RENDER_CTR,
FONT_DRIVER_RENDER_WIIU,
diff --git a/griffin/griffin.c b/griffin/griffin.c
index a76f34f015..724ef5973d 100644
--- a/griffin/griffin.c
+++ b/griffin/griffin.c
@@ -498,6 +498,10 @@ FONTS
#include "../gfx/drivers_font/xdk1_xfonts.c"
#endif
+#if defined(PS2)
+#include "../gfx/drivers_font/ps2_font.c"
+#endif
+
#if defined(VITA)
#include "../gfx/drivers_font/vita2d_font.c"
#endif