mirror of
https://github.com/libretro/ppsspp.git
synced 2025-01-07 09:00:40 +00:00
e3a953972a
Update toolchain file to reflect that we want to use clang (rock88 is using clang). Set target in the CMake. Fix for packaging and signing (thanks rock88). Update linking to include audio and GLKit (thanks rock88). Update README
172 lines
6.1 KiB
Markdown
172 lines
6.1 KiB
Markdown
PPSSPP - a fast and portable PSP emulator
|
|
=========================================
|
|
|
|
Written by Henrik Rydgård
|
|
|
|
Released under the GPL 2.0 in November 2012
|
|
|
|
Official website:
|
|
http://www.ppsspp.org/
|
|
|
|
To contribute, see [the development page][ppsspp-devel].
|
|
|
|
For the latest source code and build instructions, see [our github page][ppsspp-repo].
|
|
|
|
Basic build instructions
|
|
------------------------
|
|
|
|
(for more detailed instructions, see [the development page][ppsspp-devel])
|
|
|
|
First of all, after having checked out the source, don't forget to
|
|
run:
|
|
|
|
git submodule update --init
|
|
|
|
in order to get the "native" library.
|
|
|
|
Now, the actual building:
|
|
|
|
PPSSPP currently uses CMake for its build system. In order
|
|
to build for most systems, create a `build` directory and
|
|
run:
|
|
|
|
cmake path/to/ppsspp
|
|
make
|
|
|
|
Alternatively, run b.sh which will create the directory for you.
|
|
|
|
You can specify the -G parameter to cmake to choose a generator.
|
|
The `NMake Makefiles`, `Visual Studio 11` (projects + sln),
|
|
`GNU Makefiles` and `Unix Makefiles` generators have been tested.
|
|
|
|
Of course in-tree builds are supported, but that makes cleanup
|
|
harder to do; with out-of-tree builds you can just remove the
|
|
`build` directory.
|
|
|
|
Note: There is also a Qt frontend available. Simply open
|
|
PPSSPPQt.pro in [Qt Creator 2.6+][qt-creator] and press run. The
|
|
Qt frontend currently supports Windows, Linux, Blackberry 10,
|
|
Symbian and Meego.
|
|
|
|
Building for Linux/BSD/etc
|
|
--------------------------
|
|
|
|
Install the libsdl1.2 (SDL 1.2) development headers. This is called
|
|
`libsdl1.2-dev` on Debian/Ubuntu, `SDL-devel` on Fedora/RHEL,
|
|
`sdl12` on BSD ports.
|
|
|
|
Currently the user interface is identical to Android's, operated
|
|
with the mouse.
|
|
|
|
Alternatively, a Qt-based frontend is available in the Qt/ dir.
|
|
Open PPSSPPQt.pro with Qt Creator.
|
|
Install libsdl1.2 if you want to use USB Gamepad.
|
|
If the build has an error about finding mobility or multimedia:
|
|
- Install the package "qtmobility-dev"
|
|
|
|
Building for OSX
|
|
----------------
|
|
|
|
Install the Xcode Command Line Tools and, using macports, fink or
|
|
homebrew, install the SDL development headers. This is called `sdl`
|
|
on homebrew. Just follow the basic build instructions afterwards.
|
|
|
|
Currently the user interface is identical to Android's, operated
|
|
with the mouse. A Qt-based interface is planned.
|
|
|
|
Building for Android
|
|
--------------------
|
|
|
|
To build for android, first you must set the ANDROID\_NDK environment
|
|
variable to point to the path of your NDK install. This is done on
|
|
windows cmd with `set ANDROID_NDK=X:\...`, on bourne shells with
|
|
`export ANDROID_NDK=/path/to/ndk`, and on C shells with
|
|
`setenv ANDROID_NDK /path/to/ndk`.
|
|
|
|
Create a `build-android` directory and inside it run:
|
|
|
|
cmake -DCMAKE_TOOLCHAIN_FILE=path/to/ppsspp/android/android.toolchain.cmake path/to/ppsspp
|
|
make
|
|
|
|
After `make` finishes, it will have created the needed .so files in
|
|
path/to/ppsspp/android/libs/armeabi-v7a. You can now use the build.xml
|
|
in the android/ dir to build the final executable, or import the android/
|
|
folder as an existing project in Eclipse.
|
|
|
|
Note that Eclipse won't notice if you have made changes to the C++ code.
|
|
Introduce a meaningless change to a random .java file such as a whitespace
|
|
to get Eclipse to rebuild the project.
|
|
|
|
Also note that the `Visual Studio` generators aren't compatible with compilers
|
|
other than Microsoft's, but `NMake Makefiles` works fine.
|
|
|
|
Building for iOS
|
|
----------------
|
|
|
|
Create a `build-ios` directory and inside it run:
|
|
|
|
cmake -DCMAKE_TOOLCHAIN_FILE=../ios/ios.toolchain.cmake -GXcode ..
|
|
|
|
Then open the generated project in Xcode.
|
|
|
|
For more information, see: http://code.google.com/p/ios-cmake/wiki/HowTo
|
|
|
|
Building for Blackberry
|
|
-----------------------
|
|
|
|
To build for Blackberry, you must first have the [latest Native SDK][blackberry-ndk] installed.
|
|
|
|
To set up your environment for cross-compiling you must then use:
|
|
|
|
source ~/bbndk/bbndk-env.sh
|
|
|
|
Finally, you are ready to compile. Go to ppsspp/Blackberry/ and run:
|
|
|
|
./build.sh
|
|
|
|
If you are on Windows, you will need GNU and CMake to run the bash script.
|
|
|
|
Alternatively, you can use the Qt frontend by compiling the PPSSPPQt.pro in
|
|
the Qt/ directory with `qmake` from the NDK or [QtCreator 2.6+][qt-creator].
|
|
|
|
Building for Symbian
|
|
--------------------
|
|
|
|
To build for Symbian, you require:
|
|
|
|
1) [GCC 4.6.3][symbian-gcc] from Mentor Graphics.
|
|
|
|
2) Symbian Qt libraries. You can find these in the final Nokia Qt SDK or online.
|
|
|
|
3) Set up your SDK to use Symbian GCCE 4.6.3. See a tutorial here: http://www.summeli.fi/?p=4220
|
|
You will need to add the GCCE 4.6.3 variant to Symbian\tools\sbs\lib\config\variants.xml as follows:
|
|
<var name="gcce4_6_3" extends="gcce_base">
|
|
<env name="SBS_GCCE463BIN" type="toolchainpath" />
|
|
<set name="GCCEBIN" value="$(SBS_GCCE463BIN)" />
|
|
<set name="GCCECC" value="$(GCCEBIN)/arm-none-symbianelf-g++$(DOTEXE)" type="tool" versionCommand="$(GCCECC) -dumpversion" versionResult="4.6.3"/>
|
|
<set name="RUNTIME_LIBS_LIST" value="drtaeabi.dso dfpaeabi.dso"/>
|
|
<set name="PLATMACROS.VAR" value="GCCE_4 GCCE_4_6"/>
|
|
<set name="ARMMACROS.VAR" value="__GCCE_4__ __GCCE_4_6__"/>
|
|
<set name="LINKER_DEFAULT_LIBS" value="-lsupc++ -lgcc -lgcc_eh"/>
|
|
<set name="PLATMACROS.CONFIG" value="ARMV6"/>
|
|
<set name="ARMMACROS.CONFIG" value="__ARMV6__"/>
|
|
<set name="LINKER_GROUP_END_OPTION" value="-Wl,--end-group"/>
|
|
<set name="LINKER_GROUP_START_OPTION" value="-Wl,--start-group"/>
|
|
<set name="CC.ARMV5" value="-march=armv6"/>
|
|
<set name="CC.SOFTVFP_MAYBE_VFPV2" value="softfp"/>
|
|
</var>
|
|
|
|
Then simply compile the PPSSPPQt.pro with `qmake` from the SDK or [QtCreator 2.6+][qt-creator].
|
|
|
|
|
|
[ppsspp-repo]: <https://github.com/hrydgard/ppsspp>
|
|
"https://github.com/hrydgard/ppsspp"
|
|
[ppsspp-devel]: <http://www.ppsspp.org/development.html>
|
|
"http://www.ppsspp.org/development.html"
|
|
[qt-creator]: <http://qt-project.org/downloads>
|
|
"http://qt-project.org/downloads"
|
|
[blackberry-ndk]: <http://developer.blackberry.com/native>
|
|
"http://developer.blackberry.com/native"
|
|
[symbian-gcc]: <http://www.mentor.com/embedded-software/sourcery-tools/sourcery-codebench/editions/lite-edition/>
|
|
"http://www.mentor.com/embedded-software/sourcery-tools/sourcery-codebench/editions/lite-edition/"
|