Skip to content
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

Set HXCPP_ARM64 by default when building on Apple Silicon Mac #1752

Merged
merged 6 commits into from
Feb 4, 2024

Conversation

tobil4sk
Copy link
Member

No description provided.

@player-03
Copy link
Contributor

player-03 commented Jan 28, 2024

I'm not a fan of the preexisting if (!targetFlags.exists()) logic. It's hard to follow, and I think it's even incorrect because it was written assuming Mac would only use Intel chips.

Looking at the code, we see that only a 64-bit machine can compile the 64-bit ndll. Makes sense.

if (!targetFlags.exists("32") && System.hostArchitecture == X64)
{
	commands.push(["-Dmac", "-DHXCPP_CLANG", "-DHXCPP_M64"]);
}

It doesn't require the "64" flag to be set, just the absence of the "32" flag. That way, the user can run the rebuild command without having to specify their architecture, and Lime will default to building for their machine, which makes sense. (I agree with the goal, but I still feel like it's harder than necessary to read the code.)

A bit further down, we see that both 32- and 64-bit machines can compile a 32-bit ndll, the former by default and the latter if the "32" flag is set.

if (!targetFlags.exists("64") && (targetFlags.exists("32") || System.hostArchitecture == X86))
{
	commands.push(["-Dmac", "-DHXCPP_CLANG", "-DHXCPP_M32"]);
}

In no case can you compile both types at once, so there isn't a clear reason for these to be separate if blocks. (This isn't wrong, just a bit confusing.)

The real problem here is that the M1 exists. What if hostArchitecture == ARM64 and the "32" flag is set? Well, then it will attempt to compile for X86, which I'm pretty sure isn't allowed.

There has to be a better way to organize all of this code. Maybe switch (System.hostArchitecture), because host architecture determines what options make sense to consider? Flags are checked second, so we're choosing between options appropriate to the host.

The old logic could produce inappropriate results, such as attempting to compile an x86 binary on ARM64, or compiling no binary when "64" is specified on a 32-bit machine. I'd argue that it makes sense to only check the flags when they're supported, and not to bother otherwise.
@tobil4sk
Copy link
Member Author

Thanks, the new version is fine with me.

@player-03
Copy link
Contributor

I was just trying to simplify the code a bit, but this is turning into a whole adventure. If I'd realized there would be this many issues, I'd have done it locally instead.

@player-03
Copy link
Contributor

player-03 commented Jan 28, 2024

Seems to be working now. But so much of this isn't relevant to this PR... Perhaps we should go back to 17ad057, and I'll make another PR for the enum changes.

@tobil4sk
Copy link
Member Author

Perhaps we should go back to 17ad057, and I'll make #1754 for the enum changes.

That's fine with me, should I revert this branch to that commit then?

@player-03
Copy link
Contributor

Yeah, I think that's for the best. (I would but I haven't figured out how to push to someone else's PR branch from the command line.)

@tobil4sk tobil4sk force-pushed the fix/mac-HXCPP_ARM64 branch from 424ef3c to 17ad057 Compare January 29, 2024 20:59
@player-03
Copy link
Contributor

Hmm, now we're back to choosing between three architectures, even though the switch (System.hostArchitecture) block implies there could be more. That's part of what I was trying to fix with 8a1c0ff.

Ok, new idea...

I don't know if there are any ARMv6 or ARMv7 Macs, but they were in the old switch block, so maybe?
@player-03
Copy link
Contributor

That ought to work the same without requiring all those changes to other files.

Other than that, I'm a bit concerned about HashLink forcing x64. That's the closest equivalent to is64 = true, but is64 = true was written without any consideration for Arm. Maybe we should do something like this?

else if (project.targetFlags.exists("hl"))
{
	targetType = "hl";
+	if (targetArchitecture != ARM64)
+	{
		targetArchitecture = X64;
+	}
}

Or perhaps if (targetArchitecture == X86)?

And why does HL force an architecture in the first place? I can only assume there's some bug when you try to compile for 32 bits, but I don't know if making an x86 machine try to compile an x64 binary is better...

@tobil4sk
Copy link
Member Author

Other than that, I'm a bit concerned about HashLink forcing x64

Hashlink bytcode isn't supported on Apple Silicon right now anyway (and I don't think lime supports hlc compilation?), so it might be fine to leave it for now until Hashlink has proper arm64 support. I imagine compiling lime.hdll on arm64 will probably require a bit more work than this flag patch. This PR will sort out the flags for the cpp target at least.

I don't know if making an x86 machine try to compile an x64 binary is better...

From what I know, 32 bit mac systems are pretty hard to come by nowadays.

@joshtynjala
Copy link
Member

and I don't think lime supports hlc compilation?

I have HL/C compilation working for Lime/OpenFL in a branch. Will be merging into 8.2.0-Dev soon.

@tobil4sk
Copy link
Member Author

And why does HL force an architecture in the first place? I can only assume there's some bug when you try to compile for 32 bits, but I don't know if making an x86 machine try to compile an x64 binary is better...

Looks like is64 = true was added in this commit: 8d72e71. Before that it was is64 = false, which was added in 59a4036, presumably because hashlink didn't have good support for 64 bit back then. It seems like the is64 = true change might just have been done to revert is64 = false, so that hashlink builds were no longer forced to be 32 bit. It doesn't seem like it would be a problem to remove this line now.

Originally, we forced compilation on x86, presumably because at the time HashLink lacked good 64-bit support. When this support improved, the line was changed to force x64 compilation rather than being removed, which may have been a mistake. Now that there are even more valid architectures, it just doesn't make sense to force one.
@tobil4sk
Copy link
Member Author

tobil4sk commented Feb 3, 2024

Looks like Linux and Windows also have equivalent lines to the is64 = true line we discussed here, but I suppose we should stick to macos in this PR. Is there anything else that needs to be done here?

@player-03 player-03 merged commit 6fe43ea into openfl:develop Feb 4, 2024
23 checks passed
@tobil4sk
Copy link
Member Author

tobil4sk commented Feb 4, 2024

Thanks!

@tobil4sk tobil4sk deleted the fix/mac-HXCPP_ARM64 branch February 4, 2024 11:49
@joshtynjala
Copy link
Member

Based on the title alone, this PR initially sounded to me like something that shouldn't go into a hypothetical Lime 8.1.2 bug fix release, and should wait for Lime 8.2.0, so I was concerned to see that this was merged into develop instead of 8.2.0-Dev.

However, I just pulled from develop, rebuilt Lime tools, and I'm seeing that lime rebuild mac and lime build mac are both still creating x86_64 binaries on my Apple Silicon Mac.

Could it be because my Haxe is compiled for x86_64, and is running in Rosetta, so Lime tools is being tricked into thinking that it is running on x86_64 instead of Apple Silicon? If that's the case, then I'm much less concerned about this going into develop.

I just want to make sure that I understand what's going on.

@tobil4sk
Copy link
Member Author

tobil4sk commented Feb 5, 2024

lime rebuild mac and lime build mac are both still creating x86_64 binaries on my Apple Silicon Mac.

In a rosetta environment, hxp detects the host architecture to be x86_64:

https://apple.stackexchange.com/questions/420452/running-uname-m-gives-x86-64-on-m1-mac-mini

@joshtynjala
Copy link
Member

Perfect. Thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants