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

Allowing compilation on msys2 #17369

Merged
merged 1 commit into from
Jan 18, 2025
Merged

Conversation

Kreijstal
Copy link
Contributor

@Kreijstal Kreijstal commented Jan 7, 2025

Description

Before there was no clear way of running msys2, and even if there was, there is no guarantee of it working, well I fixed it, and added a CI, so that we can always know if it works. Furthermore I added 2 targets more: UCRT64 and CLANG64, yes, compilation with clang64 means we can also compile with clang for windows on arm :D, plus clang has better error messages overall, anyway.

Related Issues

fixes #17367

Reviewers

Anyone, it's my first PR here.

## Description
Before there was no clear way of running msys2, and even if there was, there is no guarantee of it working, well I fixed it, and added a CI, so that we can always know if it works. Furthermore I added 2 targets more: UCRT64 and CLANG64, yes, compilation with clang64 means we can also compile with clang for windows on arm :D, plus clang has better error messages overall, anyway.

## Related Issues

libretro#17367

## Reviewers
Anyone, it's my first PR here.
@Kreijstal
Copy link
Contributor Author

image
Seems it works according to uploaded CI artifacts :D

@shurane
Copy link

shurane commented Jan 8, 2025

This is cool.

Seems like MINGW64 is kind of deprecated anyway: https://www.msys2.org/news/#2022-10-29-changing-the-default-environment-from-mingw64-to-ucrt64. Only for building on Windows 7 and below.

EDIT: Nevermind, guess you already mentioned that in the related issue.

But the docs should probably be updated to suggest that UCRT64 or CLANG64 as the default MSYS2 environment: https://docs.libretro.com/development/retroarch/compilation/windows/

@Kreijstal
Copy link
Contributor Author

Should I update the docs?

@shurane
Copy link

shurane commented Jan 8, 2025

I think it makes sense. But I just started working with RetroArch yesterday, and also wondering why it was not using UCRT64/CLANG64 instead of the MINGW64 environment.

@Kreijstal
Copy link
Contributor Author

I don't want to be too prescriptive, I'll let the retroarch team handle this for now, then :) Maybe in another PR

@shurane
Copy link

shurane commented Jan 8, 2025

I think the documentation can at least mention that UCRT64 and CLANG64 environments can also be used.

@zoltanvb
Copy link
Contributor

zoltanvb commented Jan 9, 2025

In general, RA builds are using the oldest feasible environment, to make sure the end result runs on as many devices as possible. For self-compilation, maybe better to use the default (and update the doc), but submitted code should still compile against mingw64 (as well as a number of other environments). If the platform is added as new (Windows ARM), then there is no history, so the default can be something currently reasonable.

@shurane
Copy link

shurane commented Jan 10, 2025

@zoltanvb , can still have mingw64 environment used by the buildbot or CI checks, right?

@zoltanvb
Copy link
Contributor

Not sure if I understand the question, buildbot uses cross-compiler in a Docker container, the method will not be changed by this PR.

However, the change may have negative impact for that. I believe d3d3207 was necessary to work around a problem that is still there. Is there any #ifdef you can use to exclude those 2 new targets, while keeping mingw64/32 related definition intact?

@Kreijstal
Copy link
Contributor Author

Kreijstal commented Jan 12, 2025

Not sure if I understand the question, buildbot uses cross-compiler in a Docker container, the method will not be changed by this PR.

However, the change may have negative impact for that. I believe d3d3207 was necessary to work around a problem that is still there. Is there any #ifdef you can use to exclude those 2 new targets, while keeping mingw64/32 related definition intact?

As I explained, this has to be done as a CFLAG for those targets, those targets should specify for all files the windows version themselves, and not be hardcoded otherwise it won't be compilable on modern windows...

However I think if they already use old mingw then mingw headers will themselves don't give a high value, so they will use by default old code. Now the problem is if you want to compile for old hardware on modern windows, in that case you would simply add CFLAGS the windows version you are targetting.

I saw however CI didn't complain about this change. This shouldn't affect someone compiling from windows 7 (It has to be said that msys2 doesn't support win7 there anymore, sad beep)

@LibretroAdmin
Copy link
Contributor

Tested it locally and the build seems fine so far, so we'll take the risk with this. Hopefully nightlies won't break in the process

@LibretroAdmin LibretroAdmin merged commit 90d3e0b into libretro:master Jan 18, 2025
30 checks passed
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.

Cannot compile retroarch on msys2 ucrt64.
4 participants