MacOS via Love running, but not functioning
divuyes opened this issue · 12 comments
Describe the bug
Unlike the only other bug report about running on Mac, my M'Overlay actually runs. It shows the "Waiting for dolphin..." animation and dialogue, as well as the "Waiting for melee..." animation and dialogue when Dolphin is run. However, when Melee is opened, it still says "Waiting for melee..." and it doesn't detect it no matter what I do. I have a hunch that this might be a permissions issue within Big Sur, however I am not entirely sure that is the case, and I do not know how to solve this.
Desktop (please complete the following information):
- OS: MacOS Big Sur 11.4
- Dolphin Version: Slippi 2.3.1
To Reproduce
Steps to reproduce the behavior:
- Open the m-overlay.love file
- Open Dolphin
- Load Melee
- See error
Expected behavior
I expected it to detect Melee since it detected Dolphin, however it didn't do anything and kept waiting for Melee.
Screenshots
Initial run:
Opening Slippi through Slippi Launcher:
As shown, Melee is running however not being detected, despite Dolphin being hooked.
Settings (in case it's useful):
Debug console output
[INFO - 19:05:43] [DOLPHIN] Unhooked
[DEBUG - 19:06:02] Found dolphin-emu process: /proc/32757
[INFO - 19:06:02] [DOLPHIN] Hooked
[INFO - 19:06:04] [DOLPHIN] Unhooked
[DEBUG - 19:06:07] Found dolphin-emu process: /proc/32764
[INFO - 19:06:07] [DOLPHIN] Hooked
Yeah, MacOS functionality is currently incomplete, it's why I don't have an official dmg release of it yet. I actually built a hackintosh using my old PC parts to try and work on development for it. The most I managed to do was find the dolphin process, which is the behavior you are currently seeing.
https://github.com/bkacjios/m-overlay/blob/master/source/modules/memory/osx.lua
I hit a roadblock when I found that applications on mac need a special permission called Debugging Tool Entitlement in order to attach to it and read from the processes memory.
If you or anyone else knows more about macs and could help with this, I'd really appreciate it.
Hmm. I don't know a whole lot about developing for Lua/MacOS directly, however it seems like this is a part of Hardened Runtime. Is it possible to go in Xcode and grant this entitlement?
I have no idea. I basically know nothing about mac. Even if you did grant the permissions somehow, the osx bit of code is incomplete. It would allow me to work on it again though.
When I can, I'll see if I can use Xcode to modify the entitlement permissions of it. I'm not quite sure if I can because I don't know if Xcode works with programs other than .apps, but we will see. If not, then the .love file may be able to work if converted into a .app. We shall see.
m-overlay-x64 (master-305).zip
I made a build with extra prints to output in the terminal if it managed to get the correct permissions or not. Rename it from .zip to .love
But just so you know, M'Overlay still won't work no matter what you do, but this information would help knowing I can actually properly hook and read from memory.
As expected, the new patch printed failed permissions. However, I may have found what you need to do. First, it needs to be a .app file, so I cannot do anything with the current .love file. However, once you get that, you can follow this article to enable the Hardened Runtime and grant Debugging Tool Entitlement. Obviously, any time it says in the article the camera permission, substitute it with com.apple.security.cs.debugger
.
I wonder if this would work on the love.app, since basically, it's the engine in which m-overlay runs? I'll have to get my hackintosh working again to try and start work on this again.
Okay so after some more research, I found that the application you want to read memory from ALSO needs a seperate permissions set.
com.apple.security.get-task-allow
So this would also have to be set on dolphin as well..
Well, from what I'm reading, this would require me to have a development ID, which I don't have, in order to sign my own application. This would be a huge roadblock, since I don't think they accept apps with these debug permissions set.
As much as I would love to have support for mac, it just seems like it's impossible to do so.
It also doesn't help that dolphin would have to ship with the proper permissions as well.
Oh alright. If anything changes, I'll make a new thread. However, since the future is grim, I'm gonna close this thread. Thanks for trying, at least.
Would it help to set up a donation goal? I think developer IDs cost like $99/year. There are a lot of macOS users and im sure we’d hit that goal in a few days if not even in a few hours.
It's a lot more complicated than just getting an developer ID.
Could maybe have it use Dolphins MemoryWatcher instead, but I don't know if the builds of slippi dolphin have it enabled.