-
-
Notifications
You must be signed in to change notification settings - Fork 849
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
Publish Windows on Arm build #3452
Conversation
This pull request has conflicts, please resolve those before we can evaluate the pull request. |
3a28385
to
37b8c91
Compare
Conflicts have been resolved. A maintainer will review the pull request shortly. |
it's generated by cmake (see skeleton in cmake directory) - I've added support arm64 packages for Windows into InnoSetup in master |
|
I wonder why they call it "VERY EXPERIMENTAL". OpenSSL was one of the first libraries to be ever compiled for Windows on ARM64 all the way back in 2018. I can build it locally, I mean those two DLLs. But still. Does Stellarium use OpenSSL directly? Or all network communication is done via QtNetwork? |
via QtNetwork, but winqtdeploy do not attach OpenSSL libraries, so, we should packed it by hands |
Awesome, so now we need to find out if the Qt 6 for Win ARM-64 that AppVeyor has, uses OpenSSL or Schannel. If it uses Schannel then we don't have to copy the OpenSSL DLLs in the ARM64 build. |
I don't have a Windows/arm64 platform, so, I cannot install SLP packages (W/arm64) and prepare archive for including arm64 libraries into installer. Do you have an arm64 device? |
Yes, I have a Windows Dev Kit and a personal laptop. Can you ask AppVeyor if their build of Qt for Windows ARM 64-bit uses OpenSSL or Schannel? What's SLP ? |
According to https://www.appveyor.com/docs/windows-images-software/#tools AppVeyor don't have OpenSSL for arm64 devices
|
Correct. That's I have been saying all along! They don't have OpenSSL for arm64, so how can it be possible that their build of Qt for arm64 requires OpenSSL for arm64?I need to know if they used Schannel, not OpenSSL, for QtNetwork!
|
No OpenSSL for arm64 packages for first step. What about documentation for Qt6 for Windows/arm64? |
Qt6 for Windows/arm64 says that you can use OpenSSL for Windows on ARM64. I already compiled it for ARM64 dozens of times, it's supported since 2018. The issue is knowing if AppVeyor compiled Qt with OpenSSL for Arm64 or they just used Schannel. But you are right, I'll change the build script to build the installer without OpenSSL, let's see what happens |
@alex-w All those screenshots of Stellarium on Windows ARM64 in my machine were without OpenSSL, because I compiled Qt with Schannel, not OpenSSL. |
37b8c91
to
6fda701
Compare
bd6c9a0
to
b073402
Compare
The AppVeyor configuration of the ARM64 build of Qt is broken 😑
As you can see above, AppVeyor's I'm opening a Support ticket with AppVeyor. Until that's fixed windeployqt, for Qt's ARM-64 build, is totally broken :( |
Issue created appveyor/ci#3892 |
c691aeb
to
4705d19
Compare
03a0133
to
f9ba0a8
Compare
I added a workaround for appveyor/ci#3892: https://github.com/hmartinez82/stellarium/blob/publish_arm64/util/qtpaths_workaround.bat Question: Do we need libEGL.dll/libEGLv2.dll for Qt 6 builds? I see those files for in the installed folder And: We don't need OpenSSL for the ARM64 build of Stellarium. AppVeyor didn't answer my question so I took the matter in my own hands. Their build of Qt uses Schannel instead of OpenSSL. QtNetwork was built with SChannel 🎉 The screenshot below shows the dependencies for Qt 6 Network dll, it is not linked against OpenSSL, but linked against the Schannel SSPI instead! TLS/SSL overview (Schannel SSP) Updating star catalogs is downloading files. |
No, these (and D3Dcompiler_47.dll) are necessary only for Qt5 when running ANGLE mode. A Qt6 build should include opengl32sw.dll to be able to run software OpenGL (Mesa) mode. |
I think we may skip mesa for Windows/arm64 at first step or we should prepare binaries for all Windows architectures |
@hmartinez82 please see #3414 |
@alex-w @gzotti One important fact, but also a fun one.
The fun fact is that were talking about using Mesa's LLVMPipe to have a software renderer. So I was looking into that and found the page for Gallium D3D12 driver. I think that the "Compatibility Pack" that Microsoft provides is just that Gallium driver: https://docs.mesa3d.org/drivers/d3d12.html because I see this in the logs when running Stellarium on Windows on ARM (x64 or ARM64 builds):
|
Given that all Windows on ARM devices that were launched since 2018 use Snapdragon CPUs with the same Adreno GPU family I think that this Compatibility Package will always work as the OpenGL implementation. But you are right, eventually we should provide opengl32sw.dll for Windows on ARM too. |
If it is guaranteed that all Win/arm64 systems have the d3d12 compatibility, then requiring this compatibility pack should be enough. You may add another round of tests in the startup |
Hello @hmartinez82! Please check the fresh version (development snapshot) of Stellarium: |
Hello @hmartinez82! Please check the latest stable version of Stellarium: |
Draft PR to discuss what's needed for creating the Windows on ARM installer. This requires #3450 to be merged first!
Description
The installer itself can be either x64 or x86 since what matters are the binary files it installs and they will be ARM64.
Here is what I was unable to find out:
I noticed that OpenSSL is copied from a Stellarium repository. Does Stellarium use OpenSSL directly or is it all done via QtNetwork? Would be ok to just copy the two DLLs from AppVeyor directly instead? AppVeyor does have OpenSSL 3.1 -> https://www.appveyor.com/docs/windows-images-software/#tools . Where do these (https://github.com/Stellarium/stellarium-data/releases/tag/qt-5.6) OpenSSL DLLs come from?
I ran
qtdiag
in an AppVeyor build. (See https://ci.appveyor.com/project/hernancmartinez/stellarium/builds/48227004#L68). I was trying to find out if AppVeyor's build of Qt was using OpenSSL or Schannel as its QtNetwork SSL backend. But here lies the issue: AppVeyor does not have OpenSSL compiled for Windows on ARM and I saw in qtdiag's output that it's using OpenSSL in its Qt's x64 build. If AppVeyor's build of Qt ARM64 is using OpenSSL, where are the OpenSSL binaries? (I can't run ARM64 qtdiag.exe in AppVeyor!) I asked them this at this post https://twitter.com/hmartinez82/status/1711263056549023835 . I don't know how to get in touch with AppVeyor and their Public Forum is not letting me create a new account! If someone here in the Stellarium project has a way to ask them that, please ask it for me!Where is the copying of SpoutLibrary.dll to the output folder? In my x64 builds the CMake
INSTALL
target is not copying SpoutLibrary.dll to thebin
folder even whenENABLE_SPOUT
is enabled. When I try to run Steallarium.exe I get theSpoutLibrary.dll was not found
error message until I manually copy it to the bin folder.I never used Inno Setup before. So I may need some help, for instance, where are the installer scripts?