-
Notifications
You must be signed in to change notification settings - Fork 30
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
Port forsaken to run on ARM / Pandora open source gaming hand held. #255
Comments
I've started that. I can build now a GLES / ARM / NEON build, but it Segfault when trying to draw menu. Still something wrong, not sure if it's EGL/GLES context creation or the ARM build. |
Ah that's awesome! Although I don't actually have a Pandora so I ran into a road block supporting this.. Would be interesting if it was possible to emulate the platform on my system? Did you have to make any changes to get it to work on GLES ? The main gl renderer is still immediate mode but there is support for gl2 and some for gl3 context (that still has issues) but I imagine it was minimal changes.. Would be nice to have a render_gles.c or conditionals in render_shared.c to support a GL_ES mode .. When you say NEON are you talking about this ? http://www.arm.com/products/processors/technologies/neon.php That's interesting but I don't think that Forsaken would automatically take advantage of any special SIMD instruction sets unless the compiler is enabling them for you? Good stuff though... Have you joined the chat at all? Or if you want you can email/chat with me if you want to talk about this outside the ticket.. |
Oh also the only advice I can give here would be to run the game through gdb if possible to get a stack trace and debug what's happening ? Gdb also supports running in a server/client mode so you can actually debug the hand held from your other system.. |
I had some issue with unaligned float access, giving me some "bus error", so I converted some code. About NEON, I haden't done any SIMD adaptation for now, just will do if it's too slow. I think I will fork your repo to work on the GLEs renderer, than I'll do a pull request when it's done. Chat ok, but where? |
I'm making progress. I'm going in the menu now (I had a silly mistake, it's glColorPointer(4, GL_UNSIGNED_BYTE, blabla) and not glColorPointer(4, GL_BYTE, blabla)... That was segfaulting. Here is the actual menu from the Pandora: It "Bus Error" when starting a game (and the little picture of the level is all white also). More unaligned access of float I guess. I'll do some grep of (float *) to hunt more of this and change them by some memcpy. |
Forking is great! If it's ok I'll probably want to clean up a few things to follow our conventions before we merge back into the mainline. I would love if the fork could run cleanly in it's own branch and merge back into master .. I put together a walk through a while back that shows how to nicely fork and send pull requests if it's not too much of a hassle https://github.com/ForsakenX/forsaken/wiki/Contributing If you need help I would love to setup my system to use Mesa GLES as well so I can document and add support for building in that mode. Did you use to play Forsaken online? Have friends who want to play too? Or are you just here for the coding fun? Thanks for helping out with this! |
Oh btw the wiki explains how to reach the chat https://github.com/ForsakenX/forsaken/wiki We're over at #forsaken@irc.freenode.net You can also reach me on google chat/hangout or email me directly if you desire. |
Ok, great. I'll follow the wiki and make a fork and a gles branch and so on... I never played Forsaken online (but I remember playing the single player part). |
…specific option (like screenres or keymapping)The ARM define is used to avoid Bus Error on Arm (access of float not aligned on DWORD)The HAVE_GLES define is used to change GL1 renderer in GLES rendererFixes ForsakenX#255.
No description provided.
The text was updated successfully, but these errors were encountered: