More actions
(Created page with "{{cleanup|article|Needs cleanup}} {{#seo: |title=Vita Homebrew Apps (Plugins) - GameBrew! |title_mode=append |image=vvnzrunnervita.jpg |image_alt=VVNZRunner }} {{Infobox Vita...") |
No edit summary |
||
(7 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
{{#seo: | {{#seo: | ||
|title=Vita Homebrew Apps (Plugins) - GameBrew | |title=Vita Homebrew Apps (Plugins) - GameBrew | ||
|title_mode=append | |title_mode=append | ||
|image= | |image=vvnzrunnervita2.png | ||
|image_alt=VVNZRunner | |image_alt=VVNZRunner | ||
}} | }} | ||
{{Infobox Vita Homebrews | {{Infobox Vita Homebrews | ||
|title=VVNZRunner | |title=VVNZRunner | ||
|image= | |image=vvnzrunnervita2.png | ||
|description=Kernel plugin for PS Vita that provides API to run Toshiba MeP code on Venezia | |description=Kernel plugin for PS Vita that provides API to run Toshiba MeP code on Venezia. | ||
|author=GrapheneCt | |author=GrapheneCt | ||
|lastupdated= | |lastupdated=2022/09/02 | ||
|type=Plugins | |type=Plugins | ||
|version=2.1 | |version=2.1 | ||
|license=Mixed | |license=Mixed | ||
|download=https://dlhb.gamebrew.org/vitahomebrews/vvnzrunnervita.7z | |download=https://dlhb.gamebrew.org/vitahomebrews/vvnzrunnervita.7z | ||
|website= | |website=https://www.reddit.com/r/vitahacks/comments/pfg4he/release_vvnzrunner_run_custom_code_on_venezia/ | ||
|source=https://github.com/GrapheneCt/VVNZRunner | |source=https://github.com/GrapheneCt/VVNZRunner | ||
}} | }} | ||
VVNZRunner is kernel plugin for PS Vita that provides API to run Toshiba MeP code on Venezia. | |||
Original idea from PS Vita Henkaku wiki [https://wiki.henkaku.xyz/vita/Venezia article]. | |||
VVNZRunner provides safe way to run MeP code on Venezia processor and functions to transfer data from and to Venezia SPRAM. | |||
==User guide== | |||
===V-Thread support === | |||
V-Threads are threads that run on Venezia cores. Up to 6 cores can run tasks simultaneously in normal mode and up to 7 in extended mode (enabled with sceCodecEngineChangeNumWorkerCoresMax()). | |||
All tasks that fall outside of limit will be automatically scheduled for execution. | |||
Note that even when running V-Thread, vnzBridgeExec() is blocking on ARM side. Refer to sample_mep for V-Thread creation procedure. | |||
=== Venezia memory management system === | |||
Venezia uses specific memory management system for all external memory. | |||
You must use it for any memory passed to Venezia from ARM side to ensure cache consistency. | |||
More info can be found [https://github.com/GrapheneCt/VVNZRunner/blob/main/sample_mep/include/vnz/memory.h here]. | |||
=== Sample === | |||
Sample blits some text to screen on Venezia side and displays it on ARM side. | |||
To compile MeP code use [https://github.com/TeamMolecule/mepsdk mepsdk]. | |||
Check sample Makefile for flags used to compile MeP code for Venezia. | |||
=== Usage notes === | |||
Due to the address restrictions any global variables in MeP code should be used with GET_SYMBOL_ADDR() macro. | |||
That also includes operations with function addresses. | |||
==Screenshots== | ==Screenshots== | ||
https://dlhb.gamebrew.org/vitahomebrews/ | https://dlhb.gamebrew.org/vitahomebrews/vvnzrunnervita3.png | ||
==Changelog== | |||
'''v2.1''' | |||
*Various improvements and bugfixes. | |||
*Added some comments in the runner header to explain plugin operation. | |||
'''v2.0''' | |||
*This release adds support for direct execution of MeP ELF. | |||
'''v1.0''' | |||
* First Release. | |||
== External links == | == External links == | ||
* | * GitHub - https://github.com/GrapheneCt/VVNZRunner | ||
* | * CBPS Forums - https://forum.devchroma.nl/index.php?topic=375.0 | ||
* | * Reddit - https://www.reddit.com/r/vitahacks/comments/pfg4he/release_vvnzrunner_run_custom_code_on_venezia/ | ||
Latest revision as of 03:37, 12 Ocak 2023
VVNZRunner | |
---|---|
General | |
Author | GrapheneCt |
Type | Plugins |
Version | 2.1 |
License | Mixed |
Last Updated | 2022/09/02 |
Links | |
Download | |
Website | |
Source | |
VVNZRunner is kernel plugin for PS Vita that provides API to run Toshiba MeP code on Venezia.
Original idea from PS Vita Henkaku wiki article.
VVNZRunner provides safe way to run MeP code on Venezia processor and functions to transfer data from and to Venezia SPRAM.
User guide
V-Thread support
V-Threads are threads that run on Venezia cores. Up to 6 cores can run tasks simultaneously in normal mode and up to 7 in extended mode (enabled with sceCodecEngineChangeNumWorkerCoresMax()).
All tasks that fall outside of limit will be automatically scheduled for execution.
Note that even when running V-Thread, vnzBridgeExec() is blocking on ARM side. Refer to sample_mep for V-Thread creation procedure.
Venezia memory management system
Venezia uses specific memory management system for all external memory.
You must use it for any memory passed to Venezia from ARM side to ensure cache consistency.
More info can be found here.
Sample
Sample blits some text to screen on Venezia side and displays it on ARM side.
To compile MeP code use mepsdk.
Check sample Makefile for flags used to compile MeP code for Venezia.
Usage notes
Due to the address restrictions any global variables in MeP code should be used with GET_SYMBOL_ADDR() macro.
That also includes operations with function addresses.
Screenshots
Changelog
v2.1
- Various improvements and bugfixes.
- Added some comments in the runner header to explain plugin operation.
v2.0
- This release adds support for direct execution of MeP ELF.
v1.0
- First Release.