Closed impeeza closed 1 month ago
I am waiting for devkitA64 to be updated. The fact that devkitARM is updated but not devkitA64 does mean that atmosphere can't be built with latest packages for now, yes.
Thank you so much for the quick answer.
And thank you for all your great work and effort.
If you don't mind, I will leave the issue open just for reference until all packages get updated
Hello there, Thanks for all your work, On my setup:
On a completely new installed and fresh MSYS2 environment using MSYS:
INSTALL PREREQUISITE PACKAGES
Pacman -Syuu --noconfirm --needed zip git make lz4 libnx devkitA64 devkitARM devkitarm-rules hactool switch-dev dkp-toolchain-vars switch-tools switch-mesa switch-libdrm_nouveau switch-sdl2 switch-libjpeg-turbo switch-glm gcc python python-pip
pip install lz4 pycryptodome
UPGRADE LIBNX TO LATEST CODE and APPLYING THE PR # 641
cd ~
rm -rf ~/libnx
git clone --recursive https://github.com/switchbrew/libnx.git
cd ~/libnx
git fetch origin pull/641/head
git checkout -b pullrequest FETCH_HEAD
make all -j$(nproc)
make install -j$(nproc)
~/.switch
FOLDER as prod.keys
filemkdir ~/.switch
cp "MYPROD.KEYS" ~/.switch/prod.keys
Building Atmosphère code using the Branch gcc-14
cd ~
git clone --recursive https://github.com/Atmosphere-NX/Atmosphere
cd ~/Atmosphere
git checkout gcc-14
make
Sadly didn't worked for me, I got these errors:
built ... loader_stub.bin
Checked loader stub.
Built fusee.bin...
result_get_name.cpp
In file included from T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results.hpp:23,
from T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours.hpp:28,
from T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/source/result/result_get_name.cpp:20:
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:93:60: error: expected identifier before 'this'
93 | constexpr ALWAYS_INLINE BaseType GetModule(this auto const &self) { return ResultTraits::GetModuleFromValue(self.GetValue()); }
| ^~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:93:60: error: expected ',' or '...' before 'this'
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:94:65: error: expected identifier before 'this'
94 | constexpr ALWAYS_INLINE BaseType GetDescription(this auto const &self) { return ResultTraits::GetDescriptionFromValue(self.GetValue()); }
| ^~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:94:65: error: expected ',' or '...' before 'this'
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp: In member function 'constexpr ams::result::impl::ResultBase::BaseType ams::result::impl::ResultBase:
GetModule(int)':
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:93:125: error: 'self' was not declared in this scope
93 | constexpr ALWAYS_INLINE BaseType GetModule(this auto const &self) { return ResultTraits::GetModuleFromValue(self.GetValue()); }
|
^~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp: In member function 'constexpr ams::result::impl::ResultBase::BaseType ams::result::impl::ResultBase:
GetDescription(int)':
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:94:135: error: 'self' was not declared in this scope
94 | constexpr ALWAYS_INLINE BaseType GetDescription(this auto const &self) { return ResultTraits::GetDescriptionFromValue(self.GetValue()); }
|
^~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp: In member function 'constexpr ams::result::impl::ResultBase::BaseType ams::Result::GetModule() const':
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:122:103: error: no matching function for call to 'ams::Result::GetModule() const'
122 | constexpr ALWAYS_INLINE typename Base::BaseType GetModule() const { return Base::GetModule(); }
| ~~~~~~~~~~~~~~~^~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:93:50: note: candidate: 'constexpr ams::result::impl::ResultBase::BaseType ams::result::impl::ResultBase::GetModule(int)'
93 | constexpr ALWAYS_INLINE BaseType GetModule(this auto const &self) { return ResultTraits::GetModuleFromValue(self.GetValue()); }
| ^~~~~~~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:93:50: note: candidate expects 1 argument, 0 provided
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp: In member function 'constexpr ams::result::impl::ResultBase::BaseType ams::Result::GetDescription() const':
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:123:113: error: no matching function for call to 'ams::Result::GetDescription() const'
123 | constexpr ALWAYS_INLINE typename Base::BaseType GetDescription() const { return
Base::GetDescription(); }
|
~~~~~~~~~~~~~~~~~~~~^~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:94:50: note: candidate: 'constexpr ams::result::impl::ResultBase::BaseType ams::result::impl::ResultBase::GetDescription(int)'
94 | constexpr ALWAYS_INLINE BaseType GetDescription(this auto const &self) { return ResultTraits::GetDescriptionFromValue(self.GetValue()); }
| ^~~~~~~~~~~~~~
T:/msys64/home/Impeeza/Atmosphere/libraries/libvapours/include/vapours/results/results_common.hpp:94:50: note: candidate expects 1 argument, 0 provided
make[3]: *** [/opt/devkitpro/devkitA64/base_rules:16: result_get_name.o] Error 1
make[2]: *** [/home/Impeeza/Atmosphere/libraries/config//../libstratosphere/libstratosphere.mk:111: all] Error 2
make[1]: *** [/home/Impeeza/Atmosphere/atmosphere.mk:152: libstratosphere] Error 2
make[1]: Leaving directory '/home/Impeeza/Atmosphere'
make: *** [Makefile:39: nx_release] Error 2
Again Thanks a lot for all your hard work.
@impeeza that branch requires gcc 14 devkitA64, which has not been released. I have not closed this issue or merged that code for that reason.
With the release of a new devkitA64 I was able to build latest code, even after merging the «gcc-14» branch on the main one and the code build flawless!
Thanks a lot for your help,
Closing the issue.
Using the most recent version of DevKitPro on MSYS2's MinGW64 and latest packages:
Even with latest libnx build from https://github.com/switchbrew/libnx applying the PR 641 the build ends with lots and lost of errors on the «fusee_sdram.cpp» file, errors like:
a screenshot for reference:
The error is the same using UBUNTU and same set of packages
There is any package or step I am Missing on the building?
Thanks a lot for all your hard work.