Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PlayStation Vita support #1440

Open
wants to merge 4 commits into
base: dev
Choose a base branch
from
Open

PlayStation Vita support #1440

wants to merge 4 commits into from

Conversation

scribam
Copy link
Collaborator

@scribam scribam commented Mar 5, 2024

No description provided.

@scribam scribam mentioned this pull request Mar 5, 2024
@scribam
Copy link
Collaborator Author

scribam commented Mar 5, 2024

@scribam scribam marked this pull request as draft March 5, 2024 18:39
@flyinghead
Copy link
Owner

@Rinnegatamante Do we need the "Use Simple Shaders" option? What is the benefit for users to select advanced/not simple shaders? and how to decide which setting to use?

@Rinnegatamante
Copy link

@Rinnegatamante Do we need the "Use Simple Shaders" option? What is the benefit for users to select advanced/not simple shaders? and how to decide which setting to use?

I added it cause some games were artifacting with "complete" shaders if i remember correctly.

@Rinnegatamante
Copy link

Mhhh for me it still crashes although, can we make the CI split out also the unstipped elf? (So i can look into the cause of the crash)

@scribam
Copy link
Collaborator Author

scribam commented Mar 7, 2024

@Rinnegatamante
Copy link

The crash is caused by wrong settings on vitaGL.
vitaGL needs to be compiled with HAVE_WRAPPED_ALLOCATORS=1

@scribam
Copy link
Collaborator Author

scribam commented Mar 7, 2024

New build available with vitaGL compiled with HAVE_WRAPPED_ALLOCATORS=1

@Rinnegatamante
Copy link

Oh, it seems you also used SDL2 from vdpm. That one has no vitaGL support. You need this fork: /~https://github.com/Northfear/SDL

@scribam scribam force-pushed the dev_vita branch 2 times, most recently from 1905cac to 8afd690 Compare March 8, 2024 13:06
@scribam
Copy link
Collaborator Author

scribam commented Mar 8, 2024

New build available with SDL2 from /~https://github.com/Northfear/SDL (and compiled with VIDEO_VITA_VGL=ON)

@Rinnegatamante
Copy link

New build is prefetching on gl_CompileAndLink apparently :/

Here's the coredump analysis:
https://pastebin.com/PxwiQ3Td

@flyinghead
Copy link
Owner

It looks like the crash happens in gl_CompileShader and probably caused by a NULL OpenGL function (PC == 0).
Probable stack trace:

gl_CompileShader()
gl_CompileAndLink()
initQuad()
gl_create_resources()
OpenGLRenderer::Init()

Other OpenGL functions have already been called at this point so it's not a general glad issue but it looks like at least one of these functions is missing:

glCreateShader
glShaderSource
glCompileShader
glGetShaderiv
glGetShaderInfoLog

@Rinnegatamante
Copy link

/~https://github.com/Rinnegatamante/vitaGL/blob/master/source/lookup.c#L29-L420

These are all the available gl functions resolveable via vglGetProcAddress/eglGetProcAddress/SDL_GL_GetProcAddress.
In my fork, i recall having to ifdef out some gl funcs cause unavailable on vitaGL indeed.

@flyinghead
Copy link
Owner

It looks like glDetachShader is missing, and called in gl_CompileAndLink()

@Rinnegatamante
Copy link

Rinnegatamante commented Mar 13, 2024

This last build does launch fine but has some vmem issues still when launching any rom. I'll let Bythos know.

@bythos14
Copy link

@scribam The os_InstallFaultHandler function in linux/common.cpp is overriding the one in vita_fault_handler.cpp. Fully ifdef out the ones in common.cpp for the vita

@scribam
Copy link
Collaborator Author

scribam commented Mar 13, 2024

Thank you for your help @bythos14. I pushed a commit to ifdef out the os_InstallFaultHandler and os_UninstallFaultHandler functions in linux/common.cpp for the vita.

A new build is available for testing

@bythos14
Copy link

bythos14 commented Mar 13, 2024

@scribam Also, add __vita__ to this ifdef

#if defined(__unix__)

@bythos14
Copy link

With the handler hacked in, it's now dying at sh4_sched_request due to a failed verify

@bythos14
Copy link

Invalid cycle count comes from this function:

void SCIFSerialPort::updateBaudRate()

@bythos14
Copy link

Okay, it's seemingly being caused by a sign extension on the input to SCBRR2_write, causing the input to go from 0xFF to 0xFFFFFFFF. Patching the ELF to write SCBRR2 with strb instead of str allows me to boot in game

@flyinghead
Copy link
Owner

I can reproduce the issue on Android arm32 as well. Although it doesn't crash, it's still not correct.
Looking into it.

@flyinghead
Copy link
Owner

Fixed on master: 6115a91

@Rinnegatamante
Copy link

Bythos referred that with these changes game do finally boot although performances are worse than the og Vita fork. Anything in particular that could've caused it in latest changes to the codebase?

@scribam scribam changed the base branch from dev to master March 14, 2024 17:24
@scribam
Copy link
Collaborator Author

scribam commented Mar 14, 2024

I rebased the branch onto master, removed the kubridge submodule to include it in the ci directly and squashed the latest ifdef changes

@scribam scribam marked this pull request as ready for review March 14, 2024 17:30
@flyinghead
Copy link
Owner

@Rinnegatamante it's around 500 commits if I'm not mistaken so it's hard to tell.
Do you know if this is something on the renderer side or the emulation thread size?

@bythos14
Copy link

bythos14 commented Mar 16, 2024

One reason I've found for the performance difference is the removal of the idle skip hack in the dynarec. It helps the framerate a bit in Sonic adventure. Although even with it put back in, the framerate doesn't hit 30FPS nearly as often as it did before. Haven't done much digging to figure out why, although maybe it might be related to some of the other changes in commit 095e5ed

@flyinghead
Copy link
Owner

Underclocking the SH4 should help. This is basically what idle skip was doing on some code blocks.

@bythos14
Copy link

The problem with that is that I'm already at the lowest underclock allowed in the GUI (100MHz) and I expect that trying to go lower would harm the overall performance more than help it.

@flyinghead
Copy link
Owner

Yes, it's technically possible to go below 100 MHz but deviating too much may cause other issues.

@scribam
Copy link
Collaborator Author

scribam commented Mar 23, 2024

@Rinnegatamante @bythos14 How is the new build with the last 3 commits added? Is performance good enough?

@Rinnegatamante
Copy link

On my Discord server, a guy that did test the last build reported that some games do run better, others do run worse, some games that used to crash, now run fine and some others that used to run fine, now crash. So I guess, it's ok-ish.
@bythos14 last time also reported that newer builds, in general, will require higher downclocks than older build due to new, more accurate cycling counting. (Which is why the question about the 100 MHz max downclocking)

@bythos14
Copy link

Yeah, the three latest commits shouldn't have any significant effect on performance. Having tested it a bit, below 100MHz downclock didn't provide any benefit for the games I have. So, as Rinne said, it's ok-ish

@Shinriji
Copy link

Shinriji commented Mar 25, 2024

I was the one that tested the latest build and posted at the discord server, and after that post I played some more over the weekend and my opinion slightly changed. Several popular games crashes right at the bios screen or early in-game (Crazy Taxi and several others) that used to work. Framerate of the dev build is 20%-30% worse in most of the tested games comparing to the current version, also performance of the dev build deteriorates over time (Gigawing). Loading times are also slightly worse.

There is some rare improvements, though. Some graphical glitches are fixed (Bangai-oh), and I found 2 games that actually performs better than the current version (Cleopatra Fortune and Gunbird 2).

Of course, I tested with my 15 or so games, so a small fraction of the library, and more extensive testing is needed. But right now, the current version is way better for most users.

@scribam scribam force-pushed the dev_vita branch 2 times, most recently from 4724e9d to 03f6d1e Compare May 26, 2024 19:36
@scribam
Copy link
Collaborator Author

scribam commented May 26, 2024

Branch updated with master

@scribam scribam changed the base branch from master to dev June 10, 2024 17:35
@scribam
Copy link
Collaborator Author

scribam commented Jun 10, 2024

Branch updated with latest dev

@scribam
Copy link
Collaborator Author

scribam commented Jul 7, 2024

Updated with latest dev and conflicts fixed in core/ui/gui.cpp

@scribam
Copy link
Collaborator Author

scribam commented Aug 9, 2024

Branch updated with latest master and kubridge is now installed with vdpm

Rinnegatamante and others added 4 commits December 13, 2024 17:35
Port of /~https://github.com/Rinnegatamante/flycast-vita.
Credits to @bythos14 for everything concerning the dynarec implementation and page fault handler.

Co-authored-by: bythos14 <45720552+bythos14@users.noreply.github.com>
Co-authored-by: scribam <scribam@users.noreply.github.com>
Co-authored-by: bythos14 <45720552+bythos14@users.noreply.github.com>
Allows us to take more memory for the heap
@scribam
Copy link
Collaborator Author

scribam commented Dec 13, 2024

Branch updated with latest dev

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants