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

[FEATURE] Clean up SOF DMA interface(s) #9561

Open
kv2019i opened this issue Oct 9, 2024 · 4 comments
Open

[FEATURE] Clean up SOF DMA interface(s) #9561

kv2019i opened this issue Oct 9, 2024 · 4 comments
Assignees
Labels
enhancement New feature or request Zephyr Issues only observed with Zephyr integrated
Milestone

Comments

@kv2019i
Copy link
Collaborator

kv2019i commented Oct 9, 2024

Is your feature request related to a problem? Please describe.
DMA engines are key part of the SOF and the DMA interface are used in many place (to transfer audio data, to transfer payloads of IPC message, to implement trace, to implement debug features, and so forth).

As described in the commit message and documentation added in commit 816b143 , the transition to use native Zephyr DMA interface has been one of the complex transition tasks, and this work is not complete.

Describe the solution you'd like
This issue is used to track cleanup of the DMA usage in SOF application code with following goals:

  • remove namespace overlap between SOF and Zephyr DMA APIs, making it clear which interface is used in application code (IOW, do not mix dma_ and DMA_ prefixes in definitions)
  • retain support for transition interfaces (building SOF with Zephyr but with XTOS drivers), but move the related code to separate files and/or clearly separate namespace

Describe alternatives you've considered
One option is to wait for all targets to move to Zephyr (also to native drivers) and then DMA cleanup could be done by dropping all the legacy interfaces.

Additional context
Related to enhancement work done in #9015 and #5794

@kv2019i kv2019i added enhancement New feature or request Zephyr Issues only observed with Zephyr integrated labels Oct 9, 2024
@kv2019i kv2019i self-assigned this Oct 9, 2024
@kv2019i
Copy link
Collaborator Author

kv2019i commented Oct 9, 2024

FYI @DINESHKUMARK1 -- this shouldn't interfere with work to enable Zephyr (#9549), but something to be aware of.

@lgirdwood
Copy link
Member

May be easiest to do a xtos interface removal after we have all ported to Zephyr.

@lgirdwood lgirdwood added this to the v2.12 milestone Oct 15, 2024
@lgirdwood
Copy link
Member

Tagged for v2.12, some parts may be doable by this point, we can break down work if needed.

@kv2019i
Copy link
Collaborator Author

kv2019i commented Dec 13, 2024

Work in progress, but won't be complete for 2.12. Feature cutoff for v2.12, moving this to v2.13.

@kv2019i kv2019i modified the milestones: v2.12, v2.13 Dec 13, 2024
kv2019i added a commit to kv2019i/sof that referenced this issue Dec 20, 2024
Add "sof_" namespace to dma_get()/put() calls in and modify all
uses of the interface for builds with native Zephyr drivers.

Keep the old name for XTOS builds. This reduces the amount of
code that needs to be touched, and in XTOS code, there is no
confusion with the namespaces as all dma_foo() calls are to SOF
DMA layer.

Link: thesofproject#9561
Signed-off-by: Kai Vehmanen <[email protected]>
kv2019i added a commit that referenced this issue Jan 2, 2025
Add "sof_" namespace to dma_get()/put() calls in and modify all
uses of the interface for builds with native Zephyr drivers.

Keep the old name for XTOS builds. This reduces the amount of
code that needs to be touched, and in XTOS code, there is no
confusion with the namespaces as all dma_foo() calls are to SOF
DMA layer.

Link: #9561
Signed-off-by: Kai Vehmanen <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request Zephyr Issues only observed with Zephyr integrated
Projects
None yet
Development

No branches or pull requests

2 participants