release r23
[pcsx_rearmed.git] / readme.txt
CommitLineData
303ee308 1
4ea086f6 2PCSX-ReARMed - yet another PCSX fork, ARM special
303ee308 3
c9dbba7f 4http://notaz.gp2x.de/pcsx_rearmed.php
5
303ee308 6
7About
8-----
9
10PCSX ReARMed is yet another PCSX fork based on the PCSX-Reloaded project,
11which itself contains code from PCSX, PCSX-df and PCSX-Revolution. This
12version is ARM architecture oriented and features MIPS->ARM recompiler by
3938f69a 13Ari64, NEON GTE code and more performance improvements. It was created for
14Pandora handheld, but should be usable on other devices after some code
4ea086f6 15adjustments (N900, GPH Wiz/Caanoo, PlayBook versions are also available).
303ee308 16
c069dc1b 17PCSX ReARMed features ARM NEON GPU by Exophase, that in many cases produces
18pixel perfect graphics at very high performance. There is also Una-i's GPU
19plugin from PCSX4ALL project, and traditional P.E.Op.S. one.
303ee308 20
21
06d2e1a5 22Compiling
23---------
24
3aba4185 25For libretro build, just doing "make -f Makefile.libretro" is recommended as
26it's the way libretro team is building the core and only Makefile.libretro is
27maintained by them.
28
29For standalone build, './configure && make' should work for the most part.
06d2e1a5 30
31When compiling for ARM, it's advisable to tell configure script the CPU, FPU
32and ABI that matches your target system to get best performance, like this:
33
34CFLAGS='-mcpu=cortex-a8 -mtune=cortex-a8 -mfpu=neon -mfloat-abi=softfp' ./configure
35
36Cross compilation should also work if kernel-style CROSS_COMPILE variable
37is set:
38CROSS_COMPILE='arm-none-linux-gnueabi-' ./configure
39
40
303ee308 41Usage
42-----
43
06d2e1a5 44There are several different frontends that can be built from source (one
45generic and several platform specific), so usage slightly differs depending
46on that. Most of them have a menu that can be used to run games and configure
47the emulator.
303ee308 48
33716956 49Supported CD image formats:
f932e54b 50- .bin/.cue
51- .bin/.toc
52- .img/.ccd/.sub
53- .mdf/.mds
303ee308 54- .Z/.Z.table
33716956 55- .bz/.bz.table
56- .ZNX/.ZNX.table (partial)
57- EBOOT.PBP (PSP, partial)
bab59f00 58- .cbn
303ee308 59
7ca0ce80 60CDDA (CD audio) only supported when .cue/.toc/.ccd/.mds files are present.
900acfae 61There is support for redump.org .sbi files, which can be used instead of
62.sub files to save space (name it the same as .cue/.bin, just use .sbi
63extension). This is required for Libcrypt copy protected game support.
303ee308 64
c9dbba7f 65The emulator can simulate BIOS, which means BIOS files are not required,
66however implementation is not complete and some games still need real BIOS
06d2e1a5 67to work. To use real BIOS, copy uncompressed BIOS files to bios/ directory
68which itself should be in main emulator directory.
69
70For pandora, it should be:
c9dbba7f 71[sd card]/pandora/appdata/pcsx_rearmed/bios/
06d2e1a5 72
73When the file is copied, BIOS should be selected in Options->BIOS/Plugins menu.
c9dbba7f 74
b0c8d18b 75On pandora, analog controllers are supported using nubs, but this is
76disabled by default and needs to be enabled in 'Controls' menu.
7ca0ce80 77There is also touchscreen based GunCon support, which also requires
78appropriate controller selected in controls configuration.
799b0b87 79
303ee308 80
ee78346e 81Plugins
82-------
83
84GPU (graphics) and SPU (sound) plugins can be selected in
85[BIOS/Plugins] menu:
86
c069dc1b 87builtin_gpu - this is either Exophase's ARM NEON GPU (accurate and fast,
06d2e1a5 88 available if platform supports NEON, like on pandora),
4ea086f6 89 gpu_peops or gpu_unai (depends on compile options).
90gpu_peops.so - P.E.Op.S. soft GPU, reasonably accurate but slow
91 (also found with older emulators on PC)
92gpu_unai.so - Unai's plugin from PCSX4ALL project. Faster than P.E.Op.S.
c069dc1b 93 but has some glitches.
4ea086f6 94gpu_gles.so - experimental port of P.E.Op.S. MesaGL plugin to OpenGL ES.
ee78346e 95 Occasionally faster but has lots of glitches and seems to
4ea086f6 96 be rather unstable (may crash the driver/system).
c069dc1b 97builtin_spu - P.E.Op.S. SPU plugin, optimized for ARM.
ee78346e 98spunull.so - NULL plugin, i.e. no sound emulation.
4ea086f6 99 May cause compatibility problems.
ee78346e 100
101
9c27c205 102Cheats
103------
104
105PCSX and cwcheat cheat formats are supported. PCSX .cht file can be loaded from
106"extra stuff" menu after game is loaded, while cwcheat cheats are automatically
107loaded from cheatpops.db file, if one is present in emulator's directory and
108has any cheats for the loaded game in it.
109If any of those files are successfully loaded, 'cheats' option will appear in
110the main menu where it is possible to enable/disable individual cheats.
111
112
9af2e936 113Changelog
114---------
115
623cf65e 116r23 (2022-03-14)
117* many fixes from various contributors on github and from the libretro fork
118* dynarec related slowdowns have been greatly reduced
119* many dynarec bug fixes
120+ added chd disk image support
121
bf48d3aa 122r22 (2015-02-05)
123* general: fixed a race condition/crash in threaded SPU mode
124* pandora: C64x: fixed compatibility with newer c64_tools, enabled L2 cache
125* frontend: fixed control config corruption on load for devices that are
126 disconnected on startup
127* some dma accuracy improvements, might fix occasional glitches in ff7
128* ARMv6 build and the dynarec now make use of available instructions (gizmo98)
129
52d279a5 130r21 (2015-01-12)
131+ general: added ability to run SPU emulation on a separate thread, enabled it
132 by default when multicore CPU is detected. Significant effort was made to
133 avoid any compatibility problems which the old P.E.Op.S. implementation had.
134+ pandora: added ability to run SPU emulation on TI C64x DSP by using bsp's
135 c64_tools.
136* libretro: fixed win32 build (mingw only)
137* some tweaks for the scanline effect and other things
138
3aba4185 139r20 (2014-12-25)
140* fixed various sound accuracy issues, like effects in ff7-ff9
141 for standalone build, audio will no longer slow down when emu is not fast
142 enough and stutter instead, as the former behavior causes accuracy issues.
143 Old mode can be restored in SPU plugin config options, but is not recommended.
144* savestates now save small parts of dynarec state to reduce dynarec related
145 slowdowns after savestate load
146* menu: fixed file browser issues with filesystems like exfat-fuse
147* menu: memcard manager: selected card is saved in config now
148* standalone: added some basic scanline efect
149* some CD image loading fixes
150* converted asm code to be compatible with more assemblers, like Apple's gas
151+ libretro: added Makefile.libretro and support for various platforms like
152 iOS and QNX. Makefile.libretro is recommended way to do libretro builds
153 (patches from CatalystG, squarepusher, notaz and others, see git).
154* some other minor fixes
155
101e053c 156r19 (2013-03-17)
157+ libretro: added region, multidisk support
158* more work on cdrom code
159* changed sound sync code
160* fixed masking bugs in NEON GPU (in collaboration with Exophase)
161* fixed some compatibility issues
162* various other tweaks and fixes
163
d77e7438 164r18 (2013-01-06)
165* cdrom code greatly cleaned up
166+ new GLES output mode for ARM Linux/R-Pi
167* various libretro improvements
168* fixed several compatibility regressions
169* various other tweaks and fixes
170
171r17 (2012-11-24)
06d2e1a5 172+ added overlay support for generic Linux build
173* attempted to fix sound breakage with PulseAudio
174* fixed some regressions caused by hires mode code
175* fixed some sound issues introduced in r9
176* various other tweaks
177
e7b8bfad 178r16 (2012-11-10)
179+ gpu_neon now has new hires rendering mode
180 (sometimes slow and occasionally glitchy)
181+ integrated M-HT's scale2x and eagle2x filters
182 (works for 512x256 or lower resolution games)
183+ pandora: added gamma/brightness control (requires SZ 1.52)
184* pandora: some improvements for nub support
185+ added fast forward support
186* fixed some glitches after loading savestates from r14 or earlier
187
4ea086f6 188r15 (2012-08-02)
189* various compatibility fixes
190* attempts to fix various SPU issues
191* Exophase fixed blending issue in his NEON GPU
192* fixed some potential crashes
193* gpu_unai: merged range fix from Franxis
194+ added cheat support
195+ menu: pressing a key in file list now seeks to a file
196+ new code, fixes and refactoring to improve portability:
197 support RAM offset, translation cache in data segment,
198 SDL support, multiple sound output methods, configure script
199* unified plugin names for all ports
200+ initial libretro support
201
ea1f6f2f 202r14 (2012-03-04)
203* GLES GPU: implemented frameskip
204* GLES GPU: merged some changes from schtruck/FPSE
205* Caanoo: potential workaround for save corruption
206 (always exit emulator cleanly before turning off the console
207 to reduce chance of corruption)
208* Caanoo: fixed a bug in GTE code (graphic glitches in some games)
209* Caanoo: reworked vibration support, should support more games
210* various refactoring/minor tweaks
211
3ce7adeb 212r13 (2012-01-09)
213* yet more fixes for regressions from earlier versions
214* various fixes for NEON GPU (in collaboration with Exophase)
215+ NEON GPU supports interlace mode now, but it's not always
216 enabled due to frameskip glithes (can be changed in the menu)
217* cdda should resume on savestate load now
218* fixed date display in menus to honour locale
219+ pandora: added support for minimizing the emulator (while ingame only)
220
c069dc1b 221r12 (2011-12-24)
222+ new ARM NEON GPU rasterizer from Exophase (NEON hardware required)
223+ new GPU emulation code
224+ new analog controller configurator
225* changed frameskip handling (again..), higher values supported
226* fixed several more regressions from earlier versions
227* changed cdrom code with hope for better compatibility
228* sprite optimization for PCSX4ALL plugin
229+ Caanoo: added vibration support
230
b0c8d18b 231r11 (2011-10-31)
232+ added Wiz support
233* Caanoo: fixed tv-out
234+ Caanoo/Wiz: added scaling (16bpp only)
235+ Caanoo/Wiz: added touchscreen-as-buttons input (4 sections)
236+ added .cbin support
237+ added multidisk eboot support (use "next multidisk CD" in exras menu)
238* some GTE related optimizations
239* various other optimizations
240+ added some speed hack options for slower devices
241 (get more speed at stability and correctness loss)
242* fixed several compatibility issues
243* fixed a few crash situations
244* various minor adjustments
245* maemo: merged some code from Bonapart
246* maemo: fixed BIOS issue (hopefully)
247
cbd45cda 248r10 (2011-10-10)
249+ added Caanoo port
250+ completely rewrote memory handlers
aaac9c7e 251+ added fixed frameskip option
cbd45cda 252+ added ability to change PSX clock
253+ implemented GTE dead flag detection
254* switched to larger timeslices for better performance
255* fixed some cases of flickering
aaac9c7e 256* fixed a crash in PCSX4ALL GPU plugin
257* fixed several dynarec compatibility related issues (hopefully)
cbd45cda 258* fixed multiple SPU regressions from r9 and earlier
aaac9c7e 259* fixed frame limiter issue that sometimes caused stuttering
260* fixed some minor GUI issues
261
7ca0ce80 262r9 (2011-08-13)
263* fixed various dynarec integration issues that were causing instability
264* merged latest Ari64 dynarec code for some performance improvement
265* changed frameskip handling in builtin and PCSX4ALL plugins,
266 fixes some cases where it would not work
267* merged PCSX4ALL 2.2 GPU code to it's plugin
268* fixed PCSX4ALL GPU inline asm, was miscompiling for ARMv7.
269+ added CDDA handling for eboot format
270* improved CDDA handling for all image formats that support it
271* various compatibility/accuracy improvements
272* optimized PEOPS SPU core
273* various menu adjustments
274* changed scaling options a bit, there are now two 4:3 options:
275 integer and fractional
276+ added some basic memory card manager, which allows to change
277 or remove cards (remove needed for Tenka)
278+ added GunCon support
279+ added gpuPEOPS2 plugin (peops rendering + new emulation code)
280
3938f69a 281r8 (2011-03-22)
282* improved recompiler performance for some games
283* fixed a few recompiler related compatibility issues
284 (also fixes broken memcard support in some games)
285* fixed some graphics problems caused by frameskip.
286 Note that not all problems were fixed, so if you see graphics
287 glitches try turning off frameskip or using different GPU plugin.
288+ added screenshot function
289+ added some code to attempt to sync with pandora's LCD better
290* merged a few compatibility fixes from PCSX-Reloaded
291* fixed and issue with external controllers
292* added experimental ability to use nubs as buttons
293
900acfae 294r7 (2011-03-02)
295+ implemented most used GTE operations in NEON
296* merged latest Ari64's recompiler patches
297* removed some code from the recompiler that is unneeded for R3k
298* added some special handlers for constant reads
299* some moderate builtin GPU and SPU optimizations
300+ added redump.org SBI support
301* tuned frameskip code again
302* fixed one 'analog controller not working' issue
303* fixed a crash in builtin gpu code
304* fixed cdrom slowdown issue
305* fixed my stupid bug in the recompiler that slowed down
306 recompilation a lot
307* some other refactoring
308
acb57d8d 309r6 (2011-02-10)
310+ added analog controller support using nubs (disabled by default)
311+ added control config saving
312+ added support for ingame actions (eg. savestate load)
313+ added 'auto' region option and made it default
314+ added cd swap functionality
315+ added maemo frontend from Bonapart
316 (with some tuning, source code only)
317* reworked key configuration to be less confusing
318* fixed 'SPU IRQ wait' option sometimes causing noise
319 and turned it on by default
320* fixed mono xa masking (was causing noise)
321* fixed word access macros in dfxvideo (darkness problem)
322* changed GPU DMA timing back to 1.92 levels
323* backported more fixes from PCSX-Reloaded project
324 (mostly shalma's work, see GIT)
325* fixed a few more recompiler issues
326+ fixed frameskip in builtin plugin
327
5b09a334 328r5 (2011-01-31)
329+ added support for .bz format, also partial support for
330 .znx and eboot.pbp formats
331+ merged latest cdrom code from PCSX-Reloaded project
332* fixed remaining savestate incompatibilities between PCSX4ALL
333 and P.E.Op.S. GPU plugins
334* fixed channel disable preventing irqs in P.E.Op.S. SPU plugin
335* fixed some alignment issues
336+ added handling for branches in delay slots
337+ fixed some unexpected drops to menu
338* fixed lots of recompiler related issues (see GIT)
339+ added watchdog thread to detect emulator lockups
340* minor frontend adjustments
341
c9dbba7f 342r4 (2011-01-15)
343+ added real BIOS support (and various things for it to work)
344* fixed various recompiler issues
345+ added interpreter option (useful to overcome dynarec bugs)
346* fixed some memory card related issues with HLE bios
347* rewrote frame limiter (old was sometimes sleeping needlessly)
348
ee78346e 349r3 (2011-01-05):
350+ added Pickle's port of gpu-gles from psx4m project
351+ added PCSX4ALL gpu as a plugin
352* improved gpu plugin support
353+ added savestate preview
354* various frontend fixes
355
356r2 (2010-12-29):
9af2e936 357* fixed memcard paths
358* fixed a keybind copy-paste bug
359* properly implemented pad handling
ee78346e 360 (inputs no longer control both emulated pads at once)
9af2e936 361* fixed a crash caused by framebuffer out of range access
362* fixed SWL/SWR handling (usually resulted in graphic glitches)
363* fixed BxxZAL (Medal of Honor)
364* fixed alignment crash in color space conversion code (Lunar)
365* fixed SWC2 occasional use of wrong address register (Parasite Eve)
366* fixed firstfile() handling in HLE BIOS (broken memory cards in some games)
367+ added per-game configs (controls still not saved though)
368+ added simple plugin select interface to the menu
369
ee78346e 370r1 (2010-12-25):
9af2e936 371* initial release
372
373
303ee308 374Credits / License
375-----------------
376
f932e54b 377Emulator core:
378
303ee308 379(C) 1999-2003 PCSX Team
6b8a7b88 380 (c) 1998 Vision Thing
381 Linuzappz <linuzappz@pcsx.net>
382 Shadow <shadow@pcsx.net>
383 Pete Bernett <psswitch@online.de>
384 NoComp <NoComp@mailcity.com>
385 Nik3d
386 Akumax <akumax@pcsx.net>
387
303ee308 388(C) 2005-2009 PCSX-df Team
6b8a7b88 389 (c) Ryan Schultz <schultz.ryan@gmail.com>
390 (c) Andrew Burton <adb@iinet.net.au>
391 (c) Stephen Chao <schao@myrealbox.com>
392 (c) Marcus Comstedt <marcus@mc.pp.se>
393 Stefan Sikora <hoshy@schrauberstube.de>
394
900acfae 395(C) 2009-2011 PCSX-Reloaded Team
6b8a7b88 396 edgbla (Root counters, various core/plugin fixes)
900acfae 397 shalma (GTE Divider, many core improvements, sound plugin fixes)
6b8a7b88 398 Firnis (GTE code from PCSX-Revolution Project)
399 Gabriele Gorla (MDEC decoder)
6b8a7b88 400 Peter Collingbourne (Various core/psxbios fixes)
ee78346e 401 Dario, NeToU, siveritas (Various bugfixes)
6b8a7b88 402 Wei Mingzhi (Maintainer, input plugin, iso/cheat support, misc stuff)
403
c069dc1b 404NEON GPU plugin:
3ce7adeb 405 (C) 2011-2012 Exophase
406 (C) 2011-2012 notaz
c069dc1b 407
ee78346e 408PCSX4ALL GPU plugin:
409 (C) 2010 PCSX4ALL Team
410 (C) 2010 Unai
411 Franxis <franxism@gmail.com>
412 Chui <sdl_gp32@yahoo.es>
413
414GLES plugin (psx4m project):
f932e54b 415 (C) 1999-2009 by Pete Bernert
416 EQ
417 Olli Hinkka
418 Proger
419 Pickle
420
c069dc1b 421P.E.Op.S. GPU plugin:
1775933a 422 (C) Pete Bernert and the P.E.Op.S. team
423
c069dc1b 424P.E.Op.S. SPU plugin:
1775933a 425 (C) Pete Bernert and the P.E.Op.S. team
426 (C) SPU2-X, gigaherz, Pcsx2 Development Team
427 shalma
c069dc1b 428 notaz
f932e54b 429
430MIPS->ARM recompiler:
1775933a 431 (C) 2009-2011 Ari64
6b8a7b88 432
f932e54b 433integration, optimization and frontend:
3ce7adeb 434 (C) 2010-2012 notaz
435
436Special thanks to Mednafen author, shalma/gretar and Rokas for
437various help while developing this emulator.
303ee308 438
3ce7adeb 439Some implementation ideas (and maybe code?) likely originated from
22d3b349 440MAME/smf/pSXauthor and were integrated by various people to PCSX.
441
303ee308 442Source code is released under GNU GPL license, version 2 or later.
3ce7adeb 443See COPYING included in the archive (pandora version's .pnd can be
444extracted using unsquashfs).
445
303ee308 446The source code is available in a GIT repository at:
447
448git://notaz.gp2x.de/~notaz/pcsx_rearmed.git
449