-
Notifications
You must be signed in to change notification settings - Fork 120
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
[develop]: Updates for building and running SRW on MacOS platform #1171
base: develop
Are you sure you want to change the base?
Conversation
community test configuration example for MacOS
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I know this is in draft form, so perhaps you were already planning to do this, but the Google docs version of the documentation needs to be added to the authoritative SRW documentation (particularly the RunSRW chapter) where it differs from what's already there. Normally, I'd leave the change request till the PR is fully open, but since it already has an approval, I wanted to make sure that doesn't get missed. :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me. Approving.
@@ -4,19 +4,19 @@ load("libpng/1.6.37") | |||
|
|||
load("netcdf-c/4.9.2") | |||
load("netcdf-fortran/4.6.1") | |||
load("parallelio/2.5.10") | |||
load("parallelio/2.6.2") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@natalie-perlin @RatkoVasic-NOAA are these library version changes specific for the macos stack built to enable the srw community test? are these lib updates consistent with the stack used by all other machines in srw_common?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This wouldn't work on develop branch (other machines) since SRW/WM are still using [email protected].
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i think srw common should not be changed then and explicit lib loads need to go into the mac os modulefile
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The versions of packages built in spack-stack could be tailored to whatever is needed for the repository.
This work on MacOS started when there were plans to continue with spack-stack-1.8.0 for the UFS-WM and updated package versions. Going back to use lower versions of the packages is always an option.
DESCRIPTION OF CHANGES:
Updated scripts and modulefiles to ensure SRW could be built and run on MacOS.
Building could be done using devbuild.sh script.
Running MacOS is done using standalone scripts located in ./ush/wrappers/*.
Building the UFS weather model code includes use of CXX linker instead of Fortran linker, the change of a CMakeLists.txt file for the WM is done in devbuild.sh.
Software packages mostly correspond spack-stack-1.8.0. Directions for building the sofware stack and running the SRW are included below in two separate links to documents (working copies).
Running SRW on MacOS:
https://docs.google.com/document/d/1ADfLi4Yaa25IXz7ZhGxoRlDcmvATIlRD0KI9Se-ZJ3c/edit?usp=sharing
Building spack-stack on MacOS for UFS-WM and SRW:
https://docs.google.com/document/d/1Z0L7eujZGtyeZRzcgguyZPsZpkwb2Om7UhFqQPVtxnE/edit?usp=sharing
Type of change
TESTS CONDUCTED:
Tests are conducted on three different MacOS platforms
-->
DEPENDENCIES:
A PR to the UFS-WM has been submitted: ufs-community/ufs-weather-model#2551
Current version of devbuild.sh assumes no changes to weather-model CMakeFiles.txt has been made.
DOCUMENTATION:
Documentation may need to be updated to reflect a new option to use devbuild.sh script for the build on MacOS platform.
ISSUE:
Addresses the issue mentioned in #1168
Documentation lists only CMake approach to be used on MacOS. It creates errors on MacOS, as well as requires additional steps (not documented) required for running the SRW. Adapted devbuild.sh script allows SRW to be built on MacOS.
Addressed the issue of running UFS WM on MacOS mentioned in ufs-community/ufs-weather-model#2371
CHECKLIST
LABELS (optional):
A Code Manager needs to add the following labels to this PR:
CONTRIBUTORS (optional):