We welcome contributions to rocFFT. Please follow these details to help ensure your contributions will be successfully accepted.
Please use the GitHub Issues tab to notify us of issues.
- Use your best judgment for issue creation. If your issue is already listed, upvote the issue and comment or post to provide additional details, such as how you reproduced this issue.
- If you're not sure if your issue is the same, err on the side of caution and file your issue. You can add a comment to include the issue number (and link) for the similar issue. If we evaluate your issue as being the same as the existing issue, we'll close the duplicate.
- If your issue doesn't exist, use the issue template to file a new issue.
- When filing an issue, be sure to provide as much information as possible, including script output so we can collect information about your configuration. This helps reduce the time required to reproduce your issue.
- Check your issue regularly, as we may require additional information to successfully reproduce the issue.
- You may also open an issue to ask questions to the maintainers about whether a proposed change meets the acceptance criteria, or to discuss an idea pertaining to the library.
When a contribution is submitted via a pull request, a number of automated checks are run in order to verify compilation correctness and prevent performance regressions.
These checks include:
- Building and testing the change on various OS platforms (Ubuntu, RHEL, etc.)
- Running on different GPU architectures (MI-series, Radeon series cards, etc.)
- Running benchmarks to check for performance degradation
In order for a submission to be accepted:
- It must pass all of the automated checks
- It must undergo a code review
Users can visualize our continuous integration infrastructure in: rocFFT/.jenkins
.
The GitHub "Issues" tab may also be used to discuss ideas surrounding particular features or changes before raising pull requests.
In a broad view, rocFFT library is structured as follows:
├── docs/: contains rocFFT documentation
├── library/: contains main source code and headers
├── clients/:
│ ├── bench/ : contains benchmarking code
│ ├── samples/ : contains examples
│ ├── tests/ : contains our test infrastructure
├── shared/: contains important global headers and those for linking to other applications
-
All public APIs are C89 compatible; all other library code should use c++17.
-
Our minimum supported compiler is clang 3.6.
-
Avoid CamelCase: rule applies specifically to publicly visible APIs, but is encouraged (not mandated) for internal code.
-
C and C++ code should be formatted using
clang-format
. You can use the clang-format version available inrocFFT/.clang-format
.To format a C/C++ file, use:
clang-format -style=file -i <path-to-source-file>
-
Python code should use:
yapf --style pep8
Our code contribution guidelines closely follow the model of GitHub pull-requests.
This repository follows the git flow workflow, which dictates a /master branch where releases are cut, and a /develop branch which serves as an integration branch for new code.
Note that a git extension has been developed to ease the use of the 'git flow' methodology, but requires manual installation by the user.
The following guidelines apply:
- When you create a pull request, you should target the default branch. Our current default branch is the develop branch.
- Note that releases are cut to release/rocm-rel-x.y, where x and y refer to the release major and minor numbers.
- Ensure code builds successfully.
- Do not break existing test cases
- Code must also have benchmark tests, and performance must approach the compute bound limit or memory bound limit.
New changes should include test coverage. Our testing infrastructure is located in clients/tests/
, and can be used as a reference.
The following guidelines apply:
- New functionality will only be merged with new unit tests.
- New unit tests should integrate within the existing googletest framework.
- Tests must have good code coverage.
All pull requests must pass through the checks and the code review described in the Acceptance Criteria section before they can be merged.
Once a contribution is ready to be submitted, consider the following:
-
Before you create a PR, ensure that all files have been gone through the clang formatting: clang-format -i <changed_file>
-
While creating a PR, you can take a look at a
diff
of the changes you made using the PR's "Files" tab, and verify that no unintentional changes are being submitted. -
Checks may take some time to complete. You can view their progress in the table near the bottom of the pull request page. You may also be able to use the links in the table to view logs associated with a check if it fails.
-
During code reviews, another developer will take a look through your proposed change. If any modifications are requested (or further discussion about anything is needed), they may leave a comment. You can follow up and respond to the comment, and/or create comments of your own if you have questions or ideas.
-
When a modification request has been completed, the conversation thread about it will be marked as resolved.
-
To update the code in your PR (eg. in response to a code review discussion), you can simply push another commit to the branch used in your pull request.
-
Once your contribution is approved, we will use the squash merge option from GitHub to integrate it to the corresponding branch.
All code contributed to this project will be licensed under the license identified in the LICENSE.md. Your contribution will be accepted under the same license.